不知道為什么,我自己寫的拷貝構(gòu)造函數(shù),會導(dǎo)致后面的“classA c = a + b;”?以及“return classA(_number += a._number);”報錯。以下為一個很簡單的例子,您可以直接跑一下看看。#include <iostream>using namespace std;class classA{public:?int _number;?classA(){}?classA(int number)?{??_number = number;?}?~classA(){}?/*? 問題出在我自己寫的拷貝構(gòu)造函數(shù),它會導(dǎo)致后面的“classA c = a + b;”?以及“return classA(_number += a._number);”報錯?classA(classA &a)?{??_number = a._number;?}?*/?classA operator+(classA &a)?{??return classA(_number += a._number);?}};int main(){?classA a(1),b(2);?classA c = a + b;?cout << c._number << endl;?return 0;}
1 回答

onemoo
TA貢獻(xiàn)883條經(jīng)驗 獲得超454個贊
你知道加上 const 就沒事了,但你的解釋用詞不太準(zhǔn)確,我不知道你的想法是否正確。我就直接詳細(xì)說下吧:
導(dǎo)致這個問題的原因在 a + b 這個表達(dá)式上。
operator+ 這個函數(shù)返回的是普通的 classA 類型(這樣做是對的),但這樣的函數(shù)返回值——也就是 a + b 表達(dá)式的值——算是“右值”。
普通的引用——如 classA& 這樣的——叫做“左值引用”,它們是不能引用右值對象的。所以 c 并不能用 a + b 的值(右值)作為初值,編譯器在這里就報錯了。
而 const 引用既可以引用左值對象也可以引用右值對象。
解決辦法自然就是 classA(const classA&),這樣的構(gòu)造函數(shù)既能接收普通左值對象,也能接收右值對象,所以就能夠編譯了。
- 1 回答
- 0 關(guān)注
- 1336 瀏覽
添加回答
舉報
0/150
提交
取消