在C语言的逻辑运算符中,我们知道有两个现象,与短路和或断路
所谓与短路:
就是a&&b时,当a为假时,不需要判断整个表达式,不再计算与后面的表达式,当a为真时,再判断后面的表达式。
所谓或断路:
就是a||b时,当a为真时,不需要判断整个表达式,也就是不再计算或后面的表达式,当a为假时,再判断后面的表达式。
例如:
#include <stdio.h>
int main()
{
int i = 0;
int j = 0;
if(++i>0)||(++j>0)
{
printf("i = %d, j = %d\n",i,j);
}
return 0;
}
输出结果就是i = 1, j = 0;
初学者可能会问后面的j不是自增了吗,但是我们需要知道或运算会有断路,当或前面的为1时,后面的就不参与计算,当或前面的为假时,才会判断或后面的表达式;
同样的逻辑与一样:
#include <stdio.h>
int main()
{
int i = 0;
int j = 0;
if(++i==0)&&(++j)
{
printf("i = %d, j = %d\n",i,j);
}
return 0;
}
输出结果就是i = 0, j = 0
因为在与前面为0,整个表达式已经是0了,就会被短路优化,不去判断后面的自增,整个和计算机自身的优化也有关系,与之前的博客中讲到的编译器优化程序可以联合起来看,即volatile。
注意:&&的优先级高于||
例如:
1||0&&0 结果是1
0&&1||1 结果是1