日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

C++賦值運算符_C 語言

作者:?梁唐 ? 更新時間: 2022-03-22 編程語言

C++當(dāng)中允許類對象賦值,這是通過默認(rèn)的重載賦值運算符實現(xiàn)的,它的原型如下:

Class_name & Class_name::operator=(const Class_name &);

它接受并返回一個指向類對象的引用。

將已有的對象賦給另一個對象時,將會使用重載的賦值運算符:

StringBad headline1("Celery");
StringBad knot;

knot = headline1; // 調(diào)用賦值運算符

如果是對象初始化的過程,則不一定會使用賦值運算符,比如:

StringBad metoo = knot;

像是這種情況很難說,因為metoo是一個新建的對象,它可以使用拷貝構(gòu)造函數(shù)。然而,也可以分成兩步來處理,先使用拷貝構(gòu)造函數(shù)創(chuàng)建一個臨時對象,然后在賦值的時候使用賦值運算符復(fù)制到新對象中去也是可以的。

和拷貝構(gòu)造函數(shù)類似,默認(rèn)賦值運算符的實現(xiàn)也是對成員進(jìn)行逐個復(fù)制。如果成員本身就是累對象,那么會使用這個類的賦值運算符來復(fù)制。

賦值運算符的問題在哪里呢?我們還是看下之前StringBad那個例子,

我們看下下面這段代碼:

StringBad sb("test");
StringBad sports("Spinach Leaves Bowl for Dollars");
StringBad knot;
knot = sports;

當(dāng)我們運行的時候就會遇到這樣的報錯:

報錯的原因日志里寫得很清楚,我們嘗試釋放一個沒有被分配的內(nèi)存。

會報錯的原因很簡單,因為我們執(zhí)行knot = sports的時候,兩個對象內(nèi)部的字符串指向的是同一個地址。這就導(dǎo)致了析構(gòu)knot的時候sports對象對應(yīng)的內(nèi)容已經(jīng)不存在了。

解決方案也很簡單,就是我們自己重載賦值運算符,保證不會出現(xiàn)簡單拷貝的問題。

StringBad & StringBad::operator= (const StringBad & st) {
? ? if (this == &st) return *this;
? ? delete []str;
? ? len = st.len;
? ? str = new char[len+1];
? ? std::strcpy(str, st.str);
? ? return *this;
}
欄目分類
最近更新