c/c++賦值函數(重載=號運算符) 首先c++里的各種運算符都是用函數實現的,比如=,就等號函數。 所以當用=給一個對象賦值的時候,實際調用的是=號所對應的=號函數。 分析下麵的代碼 c++ include using namespace std; class Test{ public: expl ...
c/c++賦值函數(重載=號運算符)
首先c++里的各種運算符都是用函數實現的,比如=,就等號函數。
所以當用=給一個對象賦值的時候,實際調用的是=號所對應的=號函數。
分析下麵的代碼
#include <iostream>
using namespace std;
class Test{
public:
explicit Test(){
data = 0;
}
explicit Test(int d):data(d){
cout << "C:" << this << ":"<< this->data << endl;
}
//拷貝構造函數
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;
}
重點分析下麵的函數
//重載=號運算符
Test& operator = (const Test &t){
cout << "assign" << this << endl;
if(this != &t){
data = t.data;
}
return *this;
}
分析點:
1,operator =是什麼意思
2,參數為什麼是引用類型
3,參數為什麼有const限制
4,為什麼有if(this != &t)的判斷
5,為什麼有返回值
6,為什麼返回值的類型是引用類型
分析點解答:
Test t2;
t2 = t1;//實際的運作方式是t2.operator=(t1),所以函數裡面的this就是t2
1,重載類Test的=號函數,當對類Test的對象用=號操作的時候,就會調用這個重載後的函數
2,避免調用拷貝構造函數
3,避免不小心修改里參數t裡面成員變數的值(t.data = 100;)
4,防止自己給自己賦值
5,為了能夠使用 t3 = t2 = t1。如果沒有返回值,則t3.operator=(t2=t1),的參數裡面t2=t1就沒有返回值,所以編譯不過。
6,不是引用也可以,用引用類型是防止老版本的編譯器,在return處調用拷貝構造函數,新版本的編譯器(gcc 4.8.5-20),即使不用引用類型,就不會調用拷貝構造函數。