C++超詳細講解邏輯操作符
一、邏輯運算符的原生語義
- 操作數(shù)只有兩種值( true和 false )邏
- 輯表達式不用完全計算就能確定最終值
- 最終結(jié)果只能是 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; }
輸出結(jié)果如下:
這就是邏輯操作符的短路規(guī)則,可以參照我之前寫的詳細講解邏輯運算符的使用
二、重載邏輯操作符
邏輯操作符可以重載嗎?重載邏輯操作符有什么意義?
下面看一個重載邏輯操作符示例:
#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) 運行后的值,這是為什么呢?且看下面解析。
問題的本質(zhì)分析
- C++ 通過函數(shù)調(diào)用擴展操作符的功能
- 進入函數(shù)體前必須完成所有參數(shù)的計算
- 函數(shù)參數(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)),就不難理解為什么了。核心就兩點:
1.進入函數(shù)體前必須完成所有參數(shù)的計算
2.函數(shù)參數(shù)的計算次序是不定的
一些有用的建議
- 實際工程開發(fā)中避免重載邏輯操作符
- 通過重載比較操作符代替邏輯操作符重載
- 直接使用成員函數(shù)代替邏輯操作符重載
- 使用全局函數(shù)對邏輯操作符進行重載
三、小結(jié)
- C++ 從語法上支持邏輯操作符重載
- 重載后的邏輯操作符不滿足短路法則
- 工程開發(fā)中不要重載邏輯操作符
- 通過重載比較操作符替換邏輯操作符重載
- 通過專用成員函數(shù)替換邏輯操作符重載
到此這篇關(guān)于C++超詳細講解邏輯操作符的文章就介紹到這了,更多相關(guān)C++邏輯操作符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實現(xiàn)分水嶺算法(Watershed Algorithm)
這篇文章主要為大家詳細介紹了C++實現(xiàn)分水嶺算法Watershed Algorithm,具有一定的參考價值,感興趣的小伙伴們可以參考一 下2018-01-01C 語言關(guān)于聯(lián)合體的相關(guān)知識
這篇文章主要介紹了C 語言關(guān)于聯(lián)合體的相關(guān)知識,文中講解非常細致,代碼幫助大家更好的理解學(xué)習(xí),感興趣的朋友可以了解下2020-06-06C++11新特性“=default”,“=delete”的使用
=default、=delete 是C++11的新特性,分別為:顯式缺省(告知編譯器生成函數(shù)默認(rèn)的缺省版本)和顯式刪除(告知編譯器不生成函數(shù)默認(rèn)的缺省版本),本文就來介紹一下如何使用2021-05-05