& 逻辑与 【并且】(两边的算子都是true,结果才是true)
| 逻辑或【或者】(两边的算子只要一个是true,结果就是true)
! 逻辑非(取反, !false 就是 true, !true 就是 false, 这是一个单目运算符)
^ 逻辑异或(两边的算子只要不一样,结果就是true)
&& 短路与
|| 短路或
短路与和逻辑与的最终运算结果是相同的,只不过短路与存在短路现象。
短路或和逻辑或的最终运算结果是相同的,只不过短路或存在短路现象。
5 > 3 & 5 > 2; // true
5 > 3 & 5 > 6; // false
5 > 3 | 5 > 6; // true
// 逻辑与
int main()
{
int x = 10, y = 8;
bool ans1 = x < y & ++x < y;
cout << "ans1=" << ans1 << " x=" << x << endl; // ans1=0, x=11 // x=11说明右边的表达式执行了
}
//短路与
int main()
{
int x = 10, y = 8;
bool ans2 = x < y && ++x < y;
cout << "ans2=" << ans2 << " x=" << x << endl; // ans2=0,x=10 // x=10说明右边的表达式没有执行
}
从某个角度来看,短路与更智能。由于后面的表达式可能不执行,所以执行效率较高。短路与比逻辑与用的多,短路与更常用。
但是,某些特殊的逻辑中,要求运算符两边的算子必须全部执行,此时必须使用逻辑与,不能使用短路与,使用短路与可能导致右边的表达式不执行。
什么情况下会发生短路与? 第一个表达式执行结果是false,会发生短路与。
什么情况下会发生短路或? 第一个表达式执行结果是true,会发生短路或。
😊