【C++深度剖析教程17】逻辑操作符的陷阱
今天我們來學習邏輯操作符,那么什么是邏輯操作符的陷阱呢?在講解邏輯操作符陷阱之前,我們先來回顧什么是邏輯操作符:
邏輯運算符的原生語義:
-操作數只有兩種值(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; }分析以上程序知,第一個判斷語句只打印了int func(int i) : i = 0這一個值,說明在執行if( func(0) && func(1) )這一句時,只需要知道func(0)的結果,并不需要計算func(1)的結果,就可以知道最終值。而執行第二個判斷語句的時候,就需要知道func(0)與func(1)的值才能最終確定結果的值。
好了經過以上的程序的分析,我們知道了邏輯操作符的一些性質。那么,有兩個問題:
*邏輯操作符能夠重載么?
*重載邏輯操作符有什么意義?
下面還是用一個程序,來分析我們的問題:
#include <iostream> #include <string>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 << "int 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(1) || func(0) ){cout << "Result is true!" << endl;}else{cout << "Result is false!" << endl;}return 0; }運行結果:
由打印結果看,我們的兩個判斷語句中的func(t0) && func(t1),都執行了,這說明,重載后的&&這個操作符,與它原生的語義不符,原生的語義只需要執行一個條件就行。而這個語句if( func(1) || func(0) )的執行順序也是先執行func(0),后執行func(1);
那么這里呢,就出現了一個問題,我們重載后的邏輯操作符&&與它原生的語義不符啊,原生的語義是只做一個運算就可以判斷最終結果,但是重載后的&&操作符卻需要把兩個條件都計算一下。而且重載后的||操作符的運算順序也變了。
這就是,我們所要說的邏輯操作符的陷阱!!!
總結:
-實際開發過程中,最好避免重載邏輯操作符
-重載后的邏輯操作符不滿足短路法則
-可以通過重載比較操作符替換邏輯操作符的重載
-通過專用成員函數替換邏輯操作符的重載
總結
以上是生活随笔為你收集整理的【C++深度剖析教程17】逻辑操作符的陷阱的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: html5游戏作弊码,HTML5新手必备
- 下一篇: Makefile中 -I -L -l区别