##沒有躲過的坑--重載賦值運算符的自我賦值
C++中有個很重要的事情,就是對于類重載賦值運算符,而達到我們想要的結果。?
先看看這幾行代碼:
~~~
//Window 是一個類
Window w;
w = w; // 再傻的人也不會這么干
w[i] = w[j]; // 這個情況偶爾會發生
~~~
作為一個優秀的工程師,就要考慮到任何可能的情況。
看一段更加完整的代碼:
~~~
class ScrollBar {};
class Window
{
ScrollBar *sb;
public:
Window(ScrollBar *s) : sb(s) {}
Window() = default;
Window& operator=(const Window&);
};
Window& Window::operator=(const Window& rhs)
{
delete sb;
sb = new ScrollBar(*rhs.sb);
return *this;
}
int main()
{
Window w(new ScrollBar);
Window w2(w);
}
~~~
**這段代碼到底有什么坑兒呢?**?
設想一下,如果 *this 和rhs 是同一個實例對象呢??
那么
~~~
delete sb;
sb = new ScrollBar(*rhs.sb);
~~~
就會造成嚴重的問題。
再delete sb后, 我們試圖去訪問一個已經被刪除的rhs。這當然是致命的坑兒了。
跨越這個坑兒:
~~~
if (this == &rhs)
return *this;
delete sb;
sb = new ScrollBar(*rhs.sb);
return *this;
~~~
上面這段代碼幾乎所有的教科書都會這么講,但是曾經一個arcserver的工程師跟我講,這樣同樣存在危險,不是完美的:
試想一下,如果我們delete sb后發生了異常怎么辦?這個時候,就會有存在一個沒有指向任何東西的指針。所以下面這樣寫會更好:
~~~
Window& Window::operator=(const Window& rhs)
{
if (this == &rhs)
return *this;
ScrollBar *sbOld = sb;
sb = new ScrollBar(*rhs.sb);
delete sbOld;
return *this;
}
~~~
- 前言
- deprecated關鍵字
- 指針(內存泄露)
- 頭文件相互包含(Compiler error C2653: not a class or namespace name)
- 獲取一張圖片的width和height
- This function or variable may be unsafe.
- 智能指針陷阱
- wstring與string的轉換
- windows下chrome瀏覽器插件不能安裝
- 重定義關鍵字
- 正確釋放vector的內存
- 獲取設備環境HDC
- 抽象類不能實例化對象(但是你明明定義的不是抽象類)
- 重載賦值運算符的自我賦值
- 程序中的變量未初始化
- 成對使用new和delete時要采取相同的形式
- 意想不到的除數為零
- map的初始化(插入數據)
- 正則表達式截取字符串
- 捕獲窗口之外的鼠標消息(鉤子還是??)
- 類中的靜態成員變量(static or const static)
- 有if就要有else(一定成對)
- map查找結果處理
- 使用using namespace std的壞習慣
- new一個指針數組、以及創建動態二維數組
- 使用太多的全局變量
- 沒有及時break出for循環
- vector使用erase后迭代器變成野指針
- C++函數的默認參數(重新定義默認參數)
- 0xC0000005: 讀取位置 xxx時發生訪問沖突
- std::string初始化、最快速判斷字符串為空
- 你開發的軟件安裝在C盤Program Files (x86)下產生的異常