您好,登錄后才能下訂單哦!
本篇內容介紹了“C++類中的特殊成員函數怎么用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
1、默認構造函數
默認構造函數指不需要參數就能初始化的構造函數。包含無參和所有參數有默認值兩種類型的構造函數。
2、復制構造函數
復制構造函數指使用該類的對象作為參數的構造函數。可以有其他參數,但必須提供默認值。
3、復制賦值運算符
重載等號=,將該類的對象賦值給已定義對象。
4、析構函數
沒啥可說的。
5、移動構造函數
C++11新增,該類的右值對象為參數的構造函數,其余同復制構造函數。
6、移動復制運算符
同復制賦值運算符,唯一不同是參數為右值。
看定義容易迷糊,上代碼就會很清晰:
#include <iostream> #include <string> class Foo { public: std::string s; // 默認構造函數 Foo() { std::cout << "default constructor" << std::endl; } // 復制構造函數 Foo(const Foo& foo) { std::cout << "copy constructor" << std::endl; s = foo.s; } // 復制賦值運算符 Foo& operator=(const Foo& foo) { std::cout << "copy assignment operator" << std::endl; s = foo.s; return * this;} // 移動構造函數 Foo(Foo&& foo) { std::cout << "move constructor" << std::endl; s = std::move(foo.s); } // 移動賦值運算符 Foo& operator=(Foo&& foo) { std::cout << "move assignment operator" << std::endl; s = std::move(foo.s); return *this;} }; int main() { Foo foo1; Foo foo2(foo1); foo1 = foo2; Foo foo3(std::move(foo1)); foo2 = std::move(foo3); }
用g++或者clang編譯,加上-fno-elide-constructors -std=c++0x選項。執行程序輸出如下:
default constructor
copy constructor
copy assignment operator
move constructor
move assignment operator
結果是我們預期的。需要注意的是Foo foo3 = foo1的形式會調用復制構造函數,不會調用復制賦值運算符。原因是Foo foo3 = xxx聲明和定義一個新對象,而賦值是作用在已定義對象。移動賦值運算符同理。
C++11新增了=default和=delete函數修飾符,提示編譯器使用默認或者刪除默認的特殊函數。需要注意的是這兩個修飾符只能修飾上述特殊函數,用戶可以用其對特殊函數進行裁剪。一個例子:
struct Test { // 使用默認構造函數 Test() = default; // 刪除復制賦值運算符 Test& operator=(const Test& test) = delete; // 使用默認析構函數 ~Test() = default; };
“C++類中的特殊成員函數怎么用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。