C++簡單又好用的基本運算符重載
運算符重載概念
對已有的運算符進行重新定義,賦予其另外一種功能,以適應不同的數據類型
我們知道已有的運算符有'+'、'-'、'*'、'/'等,這些運算符對於內置數據類型可以直接使用,例如int、float、double、char等等。但是如果我們定義一個類,想實現類中對象屬性的加減乘除運算,該怎麼實現呢?那就用到運算符重載的知識點瞭。
加號運算符重載
學會一個頂四個,這篇博文隻舉例加號運算符重載
成員函數實現
示例:
class Person { public: Person operator+(Person p) { Person temp; temp.m_a = this->m_a + p.m_a; temp.m_b = this->m_b + p.m_b; return temp; } int m_a; int m_b; }; int main() { Person p1, p2; p1.m_a = 10, p2.m_a=20; p1.m_b = 30, p2.m_b = 40; Person pa = p1.operator+(p2); Person pb =p1+p2; }
定義Person類,聲明兩個整型屬性,我們都知道在類內定義的函數為成員函數或者方法;這個成員函數的返回值為Person類型,意為返回的話會自動調用編譯器提供的拷貝構造函數,這個在前面的文章已經提到過,這裡註意函數名不要自定義瞭,就寫operator+,英文意思就是’+‘操作,這樣定義符合編譯器規范,可以使用簡化版的運算,然後參數也是Person類型的,這是因為我們的目的就是要實現自定義類型的運算;該函數的實現也很簡單,就是將各屬性相加後的結果返回給新的對象;主函數中pa和pb的兩個屬性均會相等,pa的調用是重載的本質調用,pb的則是簡化的調用,看一下運行結果:
全局函數實現
示例:
Person operator+(Person p1,Person p2) { Person temp; temp.m_a = p1.m_a + p2.m_a; temp.m_b = p1.m_b + p2.m_b; return temp; } Person pa = operator+(p1, p2); Person pb = p1+p2;
在類外面定義的函數為全局函數,和上面成員函數的區別就是多瞭一個Person類型的參數而已;也是新建一個對象,讓其屬性等於參數的屬性之和,最後返回這個結果,我們還是隻需要新創建一個對象來等於這個結果就行瞭,全局函數也分本質調用和簡化調用兩種。
運算符實現函數重載
運算符重載也可以發生函數重載,就是在同一個作用域下,相同函數名的函數可以實現不一樣的功能。
示例:
Person operator+(Person p1, int v) { Person temp; temp.m_a = p1.m_a + v; temp.m_b = p1.m_b + v; return temp; }
這裡是一個全局函數的寫法,傳入對象參數p1和整型數據v,讓新建對象的屬性等於傳入對象參數的屬性都和v相加並返回該結果給新創建的對象,寫完改函數就可以直接進行這樣的調用瞭:
int main() { Person p1, p2; p1.m_a = 10, p2.m_a=20; p1.m_b = 30, p2.m_b = 40; Person pa = p1 + p2; Person pb = operator+(p1, p2); Person p4 = pa + pb; Person p5 = p4 + 10; cout << "pa的屬性為:" <<pa.m_a << pa.m_b << endl; cout << "pb的屬性為:" <<pb.m_a << pb.m_b << endl; cout << "p4的屬性為:" <<p4.m_a << p4.m_b << endl; cout << "p5的屬性為:" << p5.m_a << p5.m_b << endl; }
運行效果:
總結
直接對自定義的類進行運算應該很舒服吧,反正我用著很爽,另外的減號、乘除的重載可以按照加號運算符重載的方法一步步實現,有興趣的朋友一定早已躍躍欲試瞭,感謝大傢的觀看,快去嘗試吧
到此這篇關於C++簡單又好用的基本運算符重載的文章就介紹到這瞭,更多相關C++運算符重載內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!