C++超詳細(xì)講解邏輯操作符
一、邏輯運(yùn)算符的原生語義
- 操作數(shù)只有兩種值( true和 false )邏
- 輯表達(dá)式不用完全計(jì)算就能確定最終值
- 最終結(jié)果只能是 true 或者 false
下面看一個(gè)邏輯表達(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)算符的使用
二、重載邏輯操作符
邏輯操作符可以重載嗎?重載邏輯操作符有什么意義?
下面看一個(gè)重載邏輯操作符示例:
#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ù)對(duì)邏輯操作符進(jìn)行重載
三、小結(jié)
- C++ 從語法上支持邏輯操作符重載
- 重載后的邏輯操作符不滿足短路法則
- 工程開發(fā)中不要重載邏輯操作符
- 通過重載比較操作符替換邏輯操作符重載
- 通過專用成員函數(shù)替換邏輯操作符重載
到此這篇關(guān)于C++超詳細(xì)講解邏輯操作符的文章就介紹到這了,更多相關(guān)C++邏輯操作符內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實(shí)現(xiàn)分水嶺算法(Watershed Algorithm)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)分水嶺算法Watershed Algorithm,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一 下2018-01-01C++中的vector容器對(duì)象學(xué)習(xí)筆記
這篇文章主要介紹了C++中的vector容器對(duì)象學(xué)習(xí)筆記,其中文章最后標(biāo)紅的resize與reserve方法的差別特別需要注意,需要的朋友可以參考下2016-05-05C 語言關(guān)于聯(lián)合體的相關(guān)知識(shí)
這篇文章主要介紹了C 語言關(guān)于聯(lián)合體的相關(guān)知識(shí),文中講解非常細(xì)致,代碼幫助大家更好的理解學(xué)習(xí),感興趣的朋友可以了解下2020-06-06C++11新特性“=default”,“=delete”的使用
=default、=delete 是C++11的新特性,分別為:顯式缺省(告知編譯器生成函數(shù)默認(rèn)的缺省版本)和顯式刪除(告知編譯器不生成函數(shù)默認(rèn)的缺省版本),本文就來介紹一下如何使用2021-05-05