網站首頁 編程語言 正文
一、邏輯運算符的原生語義
- 操作數只有兩種值( true和 false )邏
- 輯表達式不用完全計算就能確定最終值
- 最終結果只能是 true 或者 false
下面看一個邏輯表達式的代碼:
#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;
}
輸出結果如下:
這就是邏輯操作符的短路規則,可以參照我之前寫的詳細講解邏輯運算符的使用
二、重載邏輯操作符
邏輯操作符可以重載嗎?重載邏輯操作符有什么意義?
下面看一個重載邏輯操作符示例:
#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;
}
}
輸出結果如下:
按照短路法則,func(t0) && func(t1) 應該只執行 func(t0),這里卻輸出了func(t0) 和 func(t1) 運行后的值,這是為什么呢?且看下面解析。
問題的本質分析
- C++ 通過函數調用擴展操作符的功能
- 進入函數體前必須完成所有參數的計算
- 函數參數的計算次序是不定的
- 短路法則完全失效
邏輯操作符重載后無法完全實現原生的語義。
上述代碼等效寫法如下:
#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;
}
}
輸出結果和上面一樣:
將func(t0) && func(t1) 改寫成operator && (func(t0), func(t1)),就不難理解為什么了。核心就兩點:
1.進入函數體前必須完成所有參數的計算
2.函數參數的計算次序是不定的
一些有用的建議
- 實際工程開發中避免重載邏輯操作符
- 通過重載比較操作符代替邏輯操作符重載
- 直接使用成員函數代替邏輯操作符重載
- 使用全局函數對邏輯操作符進行重載
三、小結
- C++ 從語法上支持邏輯操作符重載
- 重載后的邏輯操作符不滿足短路法則
- 工程開發中不要重載邏輯操作符
- 通過重載比較操作符替換邏輯操作符重載
- 通過專用成員函數替換邏輯操作符重載
原文鏈接:https://blog.csdn.net/weixin_43129713/article/details/124550630
相關推薦
- 2022-03-14 has been blocked by CORS policy: Response to prefl
- 2022-10-31 理解k8s控制器DaemonSet創建及使用場景_云其它
- 2022-07-30 Linux secure 日志分析
- 2022-08-20 在python中讀取和寫入CSV文件詳情_python
- 2022-05-24 SQLServer?RANK()?排名函數的使用_MsSql
- 2023-04-01 Python關于維卷積的理解_python
- 2022-11-06 Android如何通過組合的方式自定義View_Android
- 2022-07-22 比較兩個對象屬性值是否相同方法
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支