使用new初始化對象中的指針成員時遇到的問題 在構造函數中使用new初始化指針成員,那麼析構函數中就必須使delete,並且new對應delete, new[]則對應於delete[]。 在有多個構造函數的情況下,必須以相同的方式使用new,要不用new,要不用new[],因為只存在一個析構函數,所 ...
使用new初始化對象中的指針成員時遇到的問題
在構造函數中使用new初始化指針成員,那麼析構函數中就必須使delete,並且new對應delete, new[]則對應於delete[]。
在有多個構造函數的情況下,必須以相同的方式使用new,要不用new,要不用new[],因為只存在一個析構函數,所有的構造函數都必須與虛構函數相相容。
PS. 當然在構造函數中使用new初始化指針的時候,可以把指針初始化為空(0/NULL 或者是C++11中的nullptr),因為delete不管有沒帶[]都與空指針相容。
需要自行定義一個複製構造函數和賦值構造函數,用深複製的方式把一個對象初始化給另一個對象,一個對象複製給另一個對象,如下:
複製構造函數:
- 分配足夠空間存儲複製的數據
- 複製數據,不僅僅地址
- 更新受到影響的靜態類成員
1 String:String(const String & st) 2 { 3 num_Strings++; 4 len = st.len; 5 str = new char[len+1]; 6 std::strcpy(str,st.str); 7 }
賦值構造函數:
- 檢查自我複製情況
- 釋放成員指針之前指向記憶體
- 複製數據不僅僅地址
- 返回一個指向調用對象的引用
String & String:operator=(const String & st) { if(this == &st) return *this; else delete [] str; len = st.len; str = new char[len+1]; std::strcpy(str,st.str); return *this; }