欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++賦值運(yùn)算符

 更新時(shí)間:2022年01月04日 08:42:06   作者:?梁唐  
這篇文章主要介紹了C++賦值運(yùn)算符,C++當(dāng)中允許類(lèi)對(duì)象賦值,這是通過(guò)默認(rèn)的重載賦值運(yùn)算符實(shí)現(xiàn)的,下面我們就來(lái)介紹介紹該內(nèi)容吧,,需要的朋友可以參考一下

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

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

它接受并返回一個(gè)指向類(lèi)對(duì)象的引用。

將已有的對(duì)象賦給另一個(gè)對(duì)象時(shí),將會(huì)使用重載的賦值運(yùn)算符:

StringBad headline1("Celery");
StringBad knot;

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

如果是對(duì)象初始化的過(guò)程,則不一定會(huì)使用賦值運(yùn)算符,比如:

StringBad metoo = knot;

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

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

賦值運(yùn)算符的問(wèn)題在哪里呢?我們還是看下之前StringBad那個(gè)例子,

我們看下下面這段代碼:

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

當(dāng)我們運(yùn)行的時(shí)候就會(huì)遇到這樣的報(bào)錯(cuò):

報(bào)錯(cuò)的原因日志里寫(xiě)得很清楚,我們嘗試釋放一個(gè)沒(méi)有被分配的內(nèi)存。

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

解決方案也很簡(jiǎn)單,就是我們自己重載賦值運(yùn)算符,保證不會(huì)出現(xiàn)簡(jiǎn)單拷貝的問(wè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;
}

到此這篇關(guān)于C++賦值運(yùn)算符的文章就介紹到這了,更多相關(guān)C++賦值運(yùn)算符內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言實(shí)現(xiàn)加密解密功能

    C語(yǔ)言實(shí)現(xiàn)加密解密功能

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)加密解密功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • C語(yǔ)言構(gòu)建連連看游戲(矩陣方式)

    C語(yǔ)言構(gòu)建連連看游戲(矩陣方式)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言構(gòu)建連連看游戲,采用矩陣方式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • C語(yǔ)言移除元素的三種思路講解

    C語(yǔ)言移除元素的三種思路講解

    這篇文章主要介紹了C語(yǔ)言移除元素的三種思路,總的來(lái)說(shuō)這并不是一道難題,那為什么要拿出這道題介紹?拿出這道題真正想要傳達(dá)的是解題的思路,以及不斷優(yōu)化探尋最優(yōu)解的過(guò)程。希望通過(guò)這道題能給你帶來(lái)一種解題優(yōu)化的思路
    2022-10-10
  • C++簡(jiǎn)單實(shí)現(xiàn)的全排列算法示例

    C++簡(jiǎn)單實(shí)現(xiàn)的全排列算法示例

    這篇文章主要介紹了C++簡(jiǎn)單實(shí)現(xiàn)的全排列算法,結(jié)合實(shí)例形式分析了C++排序操作的實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-07-07
  • 從C語(yǔ)言過(guò)渡到C++之const

    從C語(yǔ)言過(guò)渡到C++之const

    C++中最早引入const是為了替代#define,后來(lái)又衍生出了其它用法。這一篇中我們來(lái)詳細(xì)介紹const的各種常見(jiàn)用法。希望對(duì)大家學(xué)習(xí)C++有所幫助。
    2017-07-07
  • C++ 實(shí)現(xiàn)優(yōu)先隊(duì)列的簡(jiǎn)單實(shí)例

    C++ 實(shí)現(xiàn)優(yōu)先隊(duì)列的簡(jiǎn)單實(shí)例

    這篇文章主要介紹了C++ 實(shí)現(xiàn)優(yōu)先隊(duì)列的簡(jiǎn)單實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助大家實(shí)現(xiàn)優(yōu)先隊(duì)列,需要的朋友可以參考下
    2017-08-08
  • C語(yǔ)言排序算法之插入排序

    C語(yǔ)言排序算法之插入排序

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言排序算法之插入排序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式

    C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式

    這篇文章主要介紹了C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • c++顯式棧實(shí)現(xiàn)遞歸介紹

    c++顯式棧實(shí)現(xiàn)遞歸介紹

    大家好,本篇文章主要講的是c++顯式棧實(shí)現(xiàn)遞歸介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • Qt+OpenCV實(shí)現(xiàn)目標(biāo)檢測(cè)詳解

    Qt+OpenCV實(shí)現(xiàn)目標(biāo)檢測(cè)詳解

    這篇文章主要介紹了如何利用Qt和OpenCV中自帶xml文件實(shí)現(xiàn)目標(biāo)檢測(cè),文中的實(shí)現(xiàn)過(guò)程講解詳細(xì),感興趣的小伙伴可以動(dòng)手試一試
    2022-03-03

最新評(píng)論