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 = ((ab) > 255) ? 255 : ab;
这个是最先被人提出的,但好像楼主不认同,那就试下以下两种方式:
用逻辑或的短路:
bool tmp = ((result = ab) < 255) || (result=255);*
用逻辑与的短路:
bool tmp = ((result = a*b) >= 255) && (result=255);
完整代码:
View Code
#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;
}
}
运行效果如下:
个人拙见,不足之处欢迎指出。
好,就这些了,希望对你有帮助。
原文链接: https://www.cnblogs.com/MikeZhang/archive/2012/10/21/cppAndOrTest20121020.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/66489
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!