您好,登錄后才能下訂單哦!
本篇內容介紹了“C++ move semantic移動語義是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
在說移動語義之前 讓我們先來說說移動構造這玩意
我們都知道 深拷貝是會把在堆區的內存一起拷貝的 那么如果我們明確知道一個對象并不會再繼續使用 但是同時我們又想拿到他堆區的資源的時候 我們應該怎么辦呢? 移動構造給我們提供了這種能力 代碼如下所示:
class MoveClass { public: int* p; MoveClass() { p = new int(); std::cout << "默認構造調用" << std::endl; } ~MoveClass() { std::cout << "析構函數調用" << std::endl; if (!p) delete p; } MoveClass(MoveClass& tmp) { } MoveClass(MoveClass&& tmp) { std::cout << "移動構造函數調用" << std::endl; this->p = tmp.p; tmp.p = nullptr; } MoveClass& operator=(MoveClass&& tmp) { std::cout << "移動構造函數調用" << std::endl; this->p = tmp.p; tmp.p = nullptr; } }; MoveClass MoveClassTest(MoveClass d) { return MoveClass(); } int main() { MoveClass cc; //好 接下來我們不再想使用c了 但是堆區的資源我們并不想拷貝 那么使用如下構造方式 MoveClass d(std::move(cc)); system("pause"); }
移動前數據如下圖所示:
移動后數據如下圖所示:
程序輸出結果:
設想一個場景 我們在一個作用域申請了一個超級大的string 如下圖所示
#include <iostream> #include <string.h> void test1(std::string s) { std::cout << "test1:" << s.c_str()<<std::endl;; } void test() { std::string s = "超級大的string"; test1(s); std::cout <<"test:"<< s.c_str() << std::endl; return; } int main() { test(); system("pause"); }
運行結果如下:
你們就要說了 有啥用啊 但是只要你懂一點c++ 你就會知道 在test中的s我們是不需要了的 也就是我們在test是不想再繼續使用s的 但是在我們調用test1的時候 我們又重新拷貝了s一份 那么性能是不是就浪費了呢?如果這個string超級大 你的程序是不是就很垃呢
我們只需要簡簡單單的加一個std::move 他就不是拷貝 而只是單純的移動指針 如下
#include <iostream> #include <string.h> void test1(std::string s) { std::cout << "test1:" << s.c_str()<<std::endl;; } void test() { std::string s = "超級大的string"; test1(std::move(s)); std::cout <<"test:"<< s.c_str() << std::endl; return; } int main() { test(); system("pause"); }
運行結果如下:
“C++ move semantic移動語義是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。