下面隨筆給出c++移動構造。ios
在現實中有不少這樣的例子,咱們將錢從一個帳號轉移到另外一個帳號,將手機SIM卡轉移到另外一臺手機,將文件從一個位置剪切到另外一個位置……移動構造能夠減小沒必要要的複製,帶來性能上的提高。c++
C++11標準中提供了一種新的構造方法——移動構造。函數
C++11以前,若是要將源對象的狀態轉移到目標對象只能經過複製。在某些狀況下,咱們沒有必要複製對象——只須要移動它們。性能
C++11引入移動語義:spa
源對象資源的控制權所有交給目標對象指針
移動構造函數code
當臨時對象在被複制後,就再也不被利用了。咱們徹底能夠把臨時對象的資源直接移動,這樣就避免了多餘的複製操做。對象
何時該觸發移動構造?blog
有可被利用的臨時對象圖片
移動構造函數:
class_name ( class_name && )
1 //例:函數返回含有指針成員的對象(版本1) 2 3 //使用深層複製構造函數 4 5 //返回時構造臨時對象,動態分配將臨時對象返回到主調函數,而後刪除臨時對象。 6 7 #include<iostream> 8 9 using namespace std; 10 11 class IntNum { 12 13 public: 14 15 IntNum(int x = 0) : xptr(new int(x)){ //構造函數 16 17 cout << "Calling constructor..." << endl; 18 19 } 20 21 IntNum(const IntNum & n) : xptr(new int(*n.xptr)){//複製構造函數 22 23 cout << "Calling copy constructor..." << endl; 24 25 }; 26 27 ~IntNum(){ //析構函數 28 29 delete xptr; 30 31 cout << "Destructing..." << endl; 32 33 } 34 35 int getInt() { return *xptr; } 36 37 private: 38 39 int *xptr; 40 41 }; 42 43 //返回值爲IntNum類對象 44 45 IntNum getNum() { 46 47 IntNum a; 48 49 return a; 50 51 } 52 53 int main() { 54 55 cout<<getNum().getInt()<<endl; 56 57 return 0; 58 59 } 60 61 //運行結果: 62 63 Calling constructor... 64 65 Calling copy constructor... 66 67 Destructing... 68 69 0 70 71 Destructing...
1 //例:函數返回含有指針成員的對象(版本2) 2 3 //使用移動構造函數 4 5 //將要返回的局部對象轉移到主調函數,省去了構造和刪除臨時對象的過程。 6 7 #include<iostream> 8 9 using namespace std; 10 11 class IntNum { 12 13 public: 14 15 IntNum(int x = 0) : xptr(new int(x)){ //構造函數 16 17 cout << "Calling constructor..." << endl; 18 19 } 20 21 IntNum(const IntNum & n) : xptr(new int(*n.xptr)){//複製構造函數 22 23 cout << "Calling copy constructor..." << endl; 24 25 //注: 26 27 //•&&是右值引用 28 29 //•函數返回的臨時變量是右值 30 31 } 32 33 IntNum(IntNum && n): xptr( n.xptr){ //移動構造函數 34 35 n.xptr = nullptr; 36 37 cout << "Calling move constructor..." << endl; 38 39 } 40 41 ~IntNum(){ //析構函數 42 43 delete xptr; 44 45 cout << "Destructing..." << endl; 46 47 } 48 49 private: 50 51 int *xptr; 52 53 }; 54 55 //返回值爲IntNum類對象 56 57 IntNum getNum() { 58 59 IntNum a; 60 61 return a; 62 63 } 64 65 int main() { 66 67 cout << getNum().getInt() << endl; return 0; 68 69 } 70 71 //運行結果: 72 73 Calling constructor... 74 75 Calling move constructor... 76 77 Destructing... 78 79 0 80 81 Destructing...