C++短路求值(逻辑与、逻辑或)1、逻辑或的短路首先看如下代码: #include <iostream> using namespace std; int main() { int a = 1; cout << "a = " << a <<endl; true || (a=0); cout << "a = " << a <<endl; } 运行结果: a = 1 a = 1 逻辑或的表现形式如下: expression1 || exexpression2 这里用到了逻辑或,由于逻辑或的短路,expression1为true,则后面的expression2(即:(a=0) )不再求值,整个表达式的结果为true,所以a的值仍为1,没有改变。 2、逻辑与的短路首先看如下代码: #include <iostream> using namespace std; int main() { int a = 1; cout << "a = " << a <<endl; false && (a=3); cout << "a = " << a <<endl; } 运行结果: a=1 a=1 逻辑与的表现形式如下: expression1 && exexpression2 上述代码中用到了逻辑与,由于逻辑与的短路,expression1为false,则后面的expression2不再求值,整个的结果为false,所以a的值没有改变。 3、应用举例这里以CSDN上的一个帖子为例(http://topic.csdn.net/u/20121011/10/c7e0a805-b4e2-44db-9d71-455f5f851240.html ): 不用if语句,不用汇编,怎么使得两数之积总是小于等于255? 大家看过帖子会发现有很多方法,比如最简单的条件表达式: result = ((a*b) > 255) ? 255 : a*b; 这个是最先被人提出的,但好像楼主不认同,那就试下以下两种方式: 用逻辑或的短路: bool tmp = ((result = a*b) < 255) || (result=255); 用逻辑与的短路: bool tmp = ((result = a*b) >= 255) && (result=255); 完整代码: #include <iostream> using namespace std; int main() { int a,b,result; while (true) { cin>>a>>b; // result = ((a*b) > 255) ? 255 : a*b; // bool tmp = ((result = a*b) < 255) || (result=255); bool tmp = ((result = a*b) >= 255) && (result=255); cout<<result<<endl; } } 运行效果如下: 个人拙见,不足之处欢迎指出。 好,就这些了,希望对你有帮助。 |
|