根据运算符优先级我知道条件与高于条件或,
int x,y,z;
x=y=z=0;++x||++y&&++z;
printf("%d%d%d\n",x,y,z);
我的理解是先条件与,变为"++x||1"最后输出为111,而计算机的输出为100,难道是先运算++x经过判断为真,后面的都没运算了?但是这与优先级的排位有冲突啊?
这是逻辑运算符的短路判断造成的!
由于逻辑运算符||和&&实现判断左值的,显然如果根据左值就能够判断整个表达式真假的话,那剩下的就不用判断了!目前的C编译就是这样处理的!
对于逻辑或||,左值为真,整个表达式就为真;
对于逻辑与&&,左值为假,整个表达式就为假!
++x||++y&&++z中先执行逻辑或||左边的++x后x=1,左值为真,后面的自然就不用处理了!
由于逻辑运算符||和&&实现判断左值的,显然如果根据左值就能够判断整个表达式真假的话,那剩下的就不用判断了!目前的C编译就是这样处理的!
对于逻辑或||,左值为真,整个表达式就为真;
对于逻辑与&&,左值为假,整个表达式就为假!
++x||++y&&++z中先执行逻辑或||左边的++x后x=1,左值为真,后面的自然就不用处理了!
温馨提示:答案为网友推荐,仅供参考
第1个回答 2013-02-26
这个是C语言的优化造成的。
按照C语言对逻辑或运算优化计算的规定,当逻辑或的左运算分量满足时,不再计算逻辑或的右运算分量,而直接得到逻辑或运算的结果。由于逻辑或的右运算分量不曾计算过,所以变量y,z的值也不为变化。
按照C语言对逻辑或运算优化计算的规定,当逻辑或的左运算分量满足时,不再计算逻辑或的右运算分量,而直接得到逻辑或运算的结果。由于逻辑或的右运算分量不曾计算过,所以变量y,z的值也不为变化。
第2个回答 2013-02-26
就是这样算的
逻辑运算符从左至右还确保其操作数的计算。 但是,它们计算必要的操作数的最小数目确定表达式的结果。 这称为 “短路计算”。追问
逻辑运算符从左至右还确保其操作数的计算。 但是,它们计算必要的操作数的最小数目确定表达式的结果。 这称为 “短路计算”。追问
为什么他要先算++x 啊
追答a||b&&c
等价于
a||(b&&c)
因为&&的优先级比||的优先级高
但是计算顺序还是要从左到右进行计算,如果a非0的话,那后面的b和c都不会计算了