成员函数和友元函数实现一元运算符重载
生活随笔
收集整理的這篇文章主要介紹了
成员函数和友元函数实现一元运算符重载
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
使用友元函數實現一元運算符的重載
實現一元運算符的前置重載 即前置++a;
一元運算符重載實現一元運算符的后置重載即 a++;
后置和前置的區別就是后置的多了一個占位符 剩下的就是C++編譯器自己調用了不用C++程序員管理管理
重載左移操作符 << 實現鏈式編程
#include <iostream> using namespace std;class Complex { private:int a;int b; public: Complex(int a= 0,int b = 0){this->a = a;this->b =b;}//友元函數實現運算符前置++的重載friend Complex& operator++(Complex &c1);//友元函數實現運算符后置++的運算符重載friend Complex operator++(Complex &c1, int);friend ostream& operator<<(ostream &out,Complex &c1);void printCom(void){cout<< a << "+" << b << 'i'<< endl;}protected: private: }; //對前置運算符進行重載 // ++c1 因為最終要得到c1本身函數返回一個引用 這樣才能夠實現返回引用Complex& operator++(Complex &c1) {c1.a++;c1.b++;return c1; }//后置++的運算符重載 //因為后置++的形式和前置++的一樣 因此C++里面提供一個占位符的語法可以使用 //調用的時候C++編譯器會自動的調用帶有占位符的后置 ++的重載函數 Complex operator++(Complex &c1, int) //返歸一個元素 //函數返回值不是函數重載的判斷標志 {原理分析//return c1;//c1.a++;//c1.b++;Complex tmp = c1; //保證是c1先使用在++c1.a++;c1.b++;return tmp; } //函數重載 <<操作符 只能單個的輸出使用并不能使用多個 因為返回的不是自己 ostream& operator<<(ostream &out,Complex &c1) {out << c1.a << "+" << c1.b << endl;return out; }int main() {Complex c1(1,2),c2(3,4);Complex c3(0,0);// //++c1;//++c1;//c1.printCom();//后置的++//2. 實現//cout.operator << (c1); 在 ostream 類中添加相應的 .operator<<//但是ostream的源碼是拿不到的//因此輸入輸出;流的從在只能使用友元函數的方法實現cout<< c1 << c2 << endl; // 左移操作符放入結合順序是從左到右的cout << "hello world!" << endl;system("pause");return 0; }總結
以上是生活随笔為你收集整理的成员函数和友元函数实现一元运算符重载的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 客座编辑:刘克,男,博士,国家自然科学基
- 下一篇: 一种基于随机投影的本地差分隐私高维数值型