網(wǎng)站首頁 編程語言 正文
一、邏輯運(yùn)算符的原生語義
- 操作數(shù)只有兩種值( true和 false )邏
- 輯表達(dá)式不用完全計(jì)算就能確定最終值
- 最終結(jié)果只能是 true 或者 false
下面看一個邏輯表達(dá)式的代碼:
#include <iostream>
#include <string>
using namespace std;
int func(int i)
{
cout << "int func(int i): i = " << i << endl;
return i;
}
int main()
{
if (func(0) && func(1))
{
cout << "Result is true!" << endl;
}
else
{
cout << "Result is False!" << endl;
}
cout << endl;
if (func(0) || func(1))
{
cout << "Result is true!" << endl;
}
else
{
cout << "Result is False!" << endl;
}
return 0;
}
輸出結(jié)果如下:
這就是邏輯操作符的短路規(guī)則,可以參照我之前寫的詳細(xì)講解邏輯運(yùn)算符的使用
二、重載邏輯操作符
邏輯操作符可以重載嗎?重載邏輯操作符有什么意義?
下面看一個重載邏輯操作符示例:
#include <iostream>
using namespace std;
class Test
{
int mValue;
public:
Test(int v)
{
mValue = v;
}
int value() const
{
return mValue;
}
};
bool operator &&(const Test& l, const Test& r)
{
return l.value() && r.value();
}
bool operator ||(const Test& l, const Test& r)
{
return l.value() || r.value();
}
Test func(Test i)
{
cout << "Test func(Test i): i.value() = " << i.value() << endl;
return i;
}
int main()
{
Test t0(0);
Test t1(1);
if (func(t0) && func(t1))
{
cout << "Result is true!" << endl;
}
else
{
cout << "Result is false!" << endl;
}
cout << endl;
if (func(t0) || func(t1))
{
cout << "Result is true!" << endl;
}
else
{
cout << "Result is false!" << endl;
}
}
輸出結(jié)果如下:
按照短路法則,func(t0) && func(t1) 應(yīng)該只執(zhí)行 func(t0),這里卻輸出了func(t0) 和 func(t1) 運(yùn)行后的值,這是為什么呢?且看下面解析。
問題的本質(zhì)分析
- C++ 通過函數(shù)調(diào)用擴(kuò)展操作符的功能
- 進(jìn)入函數(shù)體前必須完成所有參數(shù)的計(jì)算
- 函數(shù)參數(shù)的計(jì)算次序是不定的
- 短路法則完全失效
邏輯操作符重載后無法完全實(shí)現(xiàn)原生的語義。
上述代碼等效寫法如下:
#include <iostream>
using namespace std;
class Test
{
int mValue;
public:
Test(int v)
{
mValue = v;
}
int value() const
{
return mValue;
}
};
bool operator &&(const Test& l, const Test& r)
{
return l.value() && r.value();
}
bool operator ||(const Test& l, const Test& r)
{
return l.value() || r.value();
}
Test func(Test i)
{
cout << "Test func(Test i): i.value() = " << i.value() << endl;
return i;
}
int main()
{
Test t0(0);
Test t1(1);
if (operator && (func(t0), func(t1)))
{
cout << "Result is true!" << endl;
}
else
{
cout << "Result is false!" << endl;
}
cout << endl;
if (operator || (func(t0), func(t1)))
{
cout << "Result is true!" << endl;
}
else
{
cout << "Result is false!" << endl;
}
}
輸出結(jié)果和上面一樣:
將func(t0) && func(t1) 改寫成operator && (func(t0), func(t1)),就不難理解為什么了。核心就兩點(diǎn):
1.進(jìn)入函數(shù)體前必須完成所有參數(shù)的計(jì)算
2.函數(shù)參數(shù)的計(jì)算次序是不定的
一些有用的建議
- 實(shí)際工程開發(fā)中避免重載邏輯操作符
- 通過重載比較操作符代替邏輯操作符重載
- 直接使用成員函數(shù)代替邏輯操作符重載
- 使用全局函數(shù)對邏輯操作符進(jìn)行重載
三、小結(jié)
- C++ 從語法上支持邏輯操作符重載
- 重載后的邏輯操作符不滿足短路法則
- 工程開發(fā)中不要重載邏輯操作符
- 通過重載比較操作符替換邏輯操作符重載
- 通過專用成員函數(shù)替換邏輯操作符重載
原文鏈接:https://blog.csdn.net/weixin_43129713/article/details/124550630
相關(guān)推薦
- 2022-05-12 Ubuntu 20.04開啟root用戶并恢復(fù)rc.local開機(jī)自啟
- 2022-07-22 idea 編譯項(xiàng)目后target包沒有resources文件
- 2022-02-28 npm install安裝報(bào)錯 gyp info it worked if it ends with
- 2022-01-31 torch.save實(shí)現(xiàn)對網(wǎng)絡(luò)結(jié)構(gòu)和模型參數(shù)的保存 & pytorch模型文件.pt .pt
- 2022-10-05 Android源碼探究之BaseDexClassLoader的使用_Android
- 2022-06-11 C#把DataTable導(dǎo)出為Excel文件_C#教程
- 2022-04-28 關(guān)于k8s中subpath的使用詳解_云其它
- 2022-08-23 Python解析器Cpython的GIL解釋器鎖工作機(jī)制_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支