您好,登錄后才能下訂單哦!
有兩種方法可以使運算符重載:
1、使重載運算符成為該類的成員函數。這允許運算符函數訪問類的私有成員。它也 允許函數使用隱式的this指針形參來訪問調用對象。
2、使重載的成員函數成為獨立分開的函數。當以這種方式重載時,運算符函數必須 聲明為類的友元才能訪問類的私有成員。
某些運算符(如流輸入運算符 >> 和流輸出運算符 <<)必須作為獨立函數重載。其他運算符既可以作為成員函數也可以作為獨立函數重載。
假設已經編寫了以下獨立重載函數代碼:
Length a(4, 2), b(1, 8), c (0); c = a + b;
該代碼將被編譯器解釋為以下形式:
Length a(4, 2), b(1, 8), c(0); c = operator+(a, b);
編譯器允許程序員使用友好的中間插入符號。但是,它將運算符視為一個普通函數,其名稱是 operator+,這有一種不是很明顯的意味。例如,來看以下語句:
c = 2 + a;
相當于以下語句:
c = operator+(2, b);
這兩個語句都能正確編譯和執行,因為 Length 類的轉換構造函數能夠在整數形參 2 之外創建一個 Length 對象。
算術和關系運算符的重載可以像成員函數的重載一樣輕松。加法運算符的重載方法如下。首先,修改類內聲明以使該運算符變成一個成員函數:
class Length { private: int len_inches; public: //修改operator+的聲明 Length operator+(Length b); //類的其余部分,省略 };
請注意,該運算符現在被聲明為釆用 Length 類型的單個運算符,這是因為作為一個成員函數,該運算符被自動通過隱式形參 this 傳遞一個 Length 對象。例如,如果編寫以下語句:
Length a(4, 2), b(1, 8), c(0); c = a + b;
則編譯器會將此語句視為以下形式的內容:
Length a(4, 2), b(1, 8), c (0); c = a.operator+ (b);
在編寫 a + b 時,重載的 + 運算符的左操作數變成了調用成員函數的對象,右操作數變成了顯式形參。伴隨著這些變化,運算符的主體被寫成如下形式的語句:
Length Length::operator+(Length b) { return Length(this->len_inches + b.len_inches); }
綜上所述,加法運算符(以及其他算術運算符和關系運算符)既可以作為成員函數,也可以作為獨立函數重載。
一般來說,更好的做法是將二元運算符重載為釆用相同類型形參的獨立函數。這是因為,與獨立運算符的重載不同,成員函數的重載通過使左側形參變成隱式的,造成了兩個形參之間的人為區別,這將允許轉換構造函數應用右側形參,但不應用左側形參,從而產生了更改形參順序的情況,導致正確的程序如果換個方式卻出現了編譯器錯誤。示例如下:
Length a(4, 2), c(0); c = a + 2; //編譯,當于 c = a.operator+ (2) c = 2 + a; //不能編譯:相當于 c = 2 .operator+ (a);
以上就是c++運算符重載的方法有哪些的詳細內容,更多請關注億速云其它相關文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。