詳解c/c++賦值函數(shù)(重載=號運算符)
首先c++里的各種運算符都是用函數(shù)實現(xiàn)的,比如=,就等號函數(shù)。
所以當用=給一個對象賦值的時候,實際調(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ù),當對類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ù)(重載=號運算符),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
C++實現(xiàn)將一個字符串中的字符替換成另一個字符串的方法
這篇文章主要介紹了C++實現(xiàn)將一個字符串中的字符替換成另一個字符串的方法,需要考慮的情況比較全面,有不錯的借鑒價值,需要的朋友可以參考下2014-09-09
C++ 使用CRC32檢測內(nèi)存映像完整性的實現(xiàn)步驟
當我們使用動態(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-12
C語言數(shù)據(jù)結(jié)構(gòu)與算法之鏈表(一)
鏈表是線性表的鏈式存儲方式。鏈表的內(nèi)存是不連續(xù)的,前一個元素存儲地址的下一個地址中存儲的不一定是下一個元素。小編今天就將帶大家深入了解一下鏈表,快來學習吧2021-12-12

