詳解c/c++賦值函數(shù)(重載=號運算符)
首先c++里的各種運算符都是用函數(shù)實現(xiàn)的,比如=,就等號函數(shù)。
所以當(dāng)用=給一個對象賦值的時候,實際調(diào)用的是=號所對應(yīng)的=號函數(shù)。
分析下面的代碼
#include <iostream> using namespace std; class Test{ public: explicit Test(){ data = 0; } explicit Test(int d):data(d){ cout << "C:" << this << ":"<< this->data << endl; } //拷貝構(gòu)造函數(shù) Test(const Test &t){ cout << "Copy:" << this << endl; data = t.data; } //重載=號運算符 Test& operator= (const Test &t){ cout << "assign" << this << endl; if(this != &t){ data = t.data; } return *this; } ~Test(){ cout << "F:" << this << ":" << this->data << endl; } private: int data; }; int main(){ Test t1(10); Test t2, t3; t3 = t2 = t1; return 0; }
重點分析下面的函數(shù)
//重載=號運算符 Test& operator = (const Test &t){ cout << "assign" << this << endl; if(this != &t){ data = t.data; } return *this; }
分析點:
1,operator =是什么意思
2,參數(shù)為什么是引用類型
3,參數(shù)為什么有const限制
4,為什么有if(this != &t)的判斷
5,為什么有返回值
6,為什么返回值的類型是引用類型
分析點解答:
Test t2;
t2 = t1;//實際的運作方式是t2.operator=(t1),所以函數(shù)里面的this就是t2
1,重載類Test的=號函數(shù),當(dāng)對類Test的對象用=號操作的時候,就會調(diào)用這個重載后的函數(shù)
2,避免調(diào)用拷貝構(gòu)造函數(shù)
3,避免不小心修改里參數(shù)t里面成員變量的值(t.data = 100;)
4,防止自己給自己賦值
5,為了能夠使用 t3 = t2 = t1。如果沒有返回值,則t3.operator=(t2=t1),的參數(shù)里面t2=t1就沒有返回值,所以編譯不過。
6,不是引用也可以,用引用類型是防止老版本的編譯器,在return處調(diào)用拷貝構(gòu)造函數(shù),新版本的編譯器(gcc 4.8.5-20),即使不用引用類型,就不會調(diào)用拷貝構(gòu)造函數(shù)。
總結(jié)
以上所述是小編給大家介紹的c/c++賦值函數(shù)(重載=號運算符),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
C++實現(xiàn)將一個字符串中的字符替換成另一個字符串的方法
這篇文章主要介紹了C++實現(xiàn)將一個字符串中的字符替換成另一個字符串的方法,需要考慮的情況比較全面,有不錯的借鑒價值,需要的朋友可以參考下2014-09-09C++ 使用CRC32檢測內(nèi)存映像完整性的實現(xiàn)步驟
當(dāng)我們使用動態(tài)補丁的時候,那么內(nèi)存中同樣不存在校驗效果,也就無法抵御對方動態(tài)修改機器碼了,為了防止解密者直接對內(nèi)存打補丁,我們需要在硬盤校驗的基礎(chǔ)上,增加內(nèi)存校驗,防止動態(tài)補丁的運用。2021-06-06淺析C++中memset,memcpy,strcpy的區(qū)別
本篇文章是對C++中memset,memcpy,strcpy的區(qū)別進行了詳細的分析介紹,需要的朋友參考下2013-07-07使用C++進行Cocos2d-x游戲開發(fā)入門過程中的要點解析
這篇文章主要介紹了使用C++進行Cocos2d-x游戲開發(fā)入門過程中的要點解析,主要針對畫面變化以及觸摸響應(yīng)方面,需要的朋友可以參考下2015-12-12C語言數(shù)據(jù)結(jié)構(gòu)與算法之鏈表(一)
鏈表是線性表的鏈?zhǔn)酱鎯Ψ绞?。鏈表的?nèi)存是不連續(xù)的,前一個元素存儲地址的下一個地址中存儲的不一定是下一個元素。小編今天就將帶大家深入了解一下鏈表,快來學(xué)習(xí)吧2021-12-12