C\C++ &&与 ||或 逻辑短路问题

结论:“或”逻辑前面为1,“与”逻辑前面为0就会发生短路

1.或逻辑短路

include

int main()
{
int a=5,b=6,c=7,d=8,m=2,n=2;
(m=ad);
printf("%d\t%d",m,n);
}
输出的结果为1,2.为什么呢,因为a ||只要有一个为1,结果就为1。因此短路.并且不计算(n=c>d);

 

2.与逻辑短路

include

int main()
{
int a=5,b=6,c=7,d=8,m=2,n=2;
(m=a>b)&&(n=c>d);
printf("%d\t%d",m,n);
}
输出的结果为0,2。因为a>b为0,m=0,整个“与”逻辑判断就为“假”,所以后面的“c>d”就被短路掉了,所以n还是等于原先的2
&&只要有一个为0,都为0.因此计算机不计算(n=c>d);

另附:别人总结
逻辑与(&)和逻辑或(|):
标准的逻辑与(&)和逻辑或(|),不论第一个表达式为true or false,都计算第二个表达式。
例如:if (c==0 | e++ < 100) { d=12;} //不论c是否等于0,e都被自增量。

短路与(&&)和短路或(||)
A&&B, 当A为false时,不去计算B的值而直接返回false;当A为true时,计算B的值。
A || B,当A为true时, 不去计算B的值而直接返回true;当A为false时,计算B的值。

3.应用比较
短路&& 是很有用的。例如,下面的程序语句说明了短路逻辑运算符的优点,用它来防止被0除的错误:
if (denom != 0 && num / denom > 10)
既然用了短路与(&&) 运算符,就不会有当denom为0时产生的意外运行时错误。如果该行代码使用标准与 运算符(&),它将对两个运算数都求值,当出现被0除的情况时,就会产生运行时错误。

你可能感兴趣的:(C\C++ &&与 ||或 逻辑短路问题)