在operator =中要处理“自我赋值”
生活随笔
收集整理的這篇文章主要介紹了
在operator =中要处理“自我赋值”
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
?
防止自我賦值很有必要
Widget w; w = w; a[i] = a[j]; //a[i]和a[j]實際上指向同一個元素 *pi = *pj; //pi和pj實際上指向同一個元素自我賦值的危害:
Widget { private:Test *p; }; Widget &Widget::operator=(const Widget &w) {delete p;p = new int (*w.p);return *this; }如果是自我賦值,會把自己的空間釋放掉,即當(dāng)執(zhí)行delete p后,w.p已經(jīng)指向一個被釋放的內(nèi)存空間(此時*w.p的內(nèi)容未知);當(dāng)執(zhí)行 p = new int(*w.p);即讓p重新指向一個存儲了(*w.p)的內(nèi)存空間,該內(nèi)存空間內(nèi)容又是未知的。當(dāng)再次引用時,會出現(xiàn)未定義的行為。
改良版本
Widget &Widget::operator=(const Widget &w) {if (this == &w){return *this;}delete p;p = new Test(*w.p);return *this; };這個類雖然能避免自我賦值的問題,但是,如果new Test時拋出異常,那么Widget最終會持有一個指針指向一塊被刪除的內(nèi)存區(qū)域,這樣的指針是有害的。
改成這樣:
Widget &Widget::operator=(const Widget &rhs) {Test *porg = p;p = new Test(*rhs.p);delete porg;return *this; }此時new Test發(fā)生異常,那么p可以保持原狀。(異常發(fā)生的時候,不會給p賦值)
delete prog;保證了p原來指向的內(nèi)存空間也會被順利釋放。
轉(zhuǎn)載于:https://www.cnblogs.com/codingmengmeng/p/9065280.html
總結(jié)
以上是生活随笔為你收集整理的在operator =中要处理“自我赋值”的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ETC黑名单有影响吗?后果严重吗?
- 下一篇: C# 通过反射获取方法/类上的自定义特性