##實戰c++中的vector系列--vector<unique_ptr<>>初始化(所有權轉移)
C++11為我們提供了智能指針,給我們帶來了很多便利的地方。
那么如果把unique_ptr作為vector容器的元素呢?
形式如出一轍:`vector<unique_ptr<int> > vec;`
但是怎么給vec添加元素呢?
看下面:
~~~
#include<iostream>
#include<vector>
#include <memory>
using namespace std;
int main()
{
vector<unique_ptr<int>> vec;
vec.push_back(1);//錯誤
return 0;
}
~~~
那么先定義一個unique_ptr,再進行push_back():
~~~
#include<iostream>
#include<vector>
#include <memory>
using namespace std;
int main()
{
vector<unique_ptr<int>> vec;
unique_ptr<int> sp(new int(126));
vec.push_back(sp);//嘗試引用已刪除的函數
return 0;
}
~~~
這就是unique智能指針的所有權問題,這個時候就需要使用std::move:
~~~
#include<iostream>
#include<vector>
#include <memory>
using namespace std;
int main()
{
vector<unique_ptr<int>> vec;
unique_ptr<int> sp(new int(126));
//vec.push_back(1);
vec.push_back(std::move(sp));//嘗試引用已刪除的函數
cout << *vec[0]<< endl; // 輸出126
//cout << *sp << endl;
return 0;
}
~~~
但是此時,上面代碼的sp編程了什么呢? 使用*取值看一下,結果程序崩潰,原因何在??
就是此時sp已經釋放,所有權轉移了!
- 前言
- 構造、operator=和assign區別
- 將迭代器轉換為索引
- copy set to vector(別混淆了reserve和resize)
- 使用vector構造二維數組
- 可怕的迭代器失效(vector重新申請內存)
- 可怕的迭代器失效之二(刪除vector中元素)
- vector<unique_ptr<>>初始化(所有權轉移)
- vector<unique_ptr<>>作為函數的參數
- vector<unique_ptr<>>賦值給vector<unique_ptr<>>
- creating vector of local structure、vector of structs initialization
- 知道emplace_back為何優于push_back嗎?
- emplace_back造成的引用失效
- vector的一些異常
- vector的遍歷(stl算法、vector迭代器(不要在循環中判斷不等于end())、operator[])
- 使用sort算法對vector進行排序(對vector<string>排序、使用穩定的排序std::stable_sort())
- vector應用之STL的find、find_if、find_end、find_first_of、find_if_not(C++11)
- 使用sort算法對vector<unique_ptr<string>>進行排序(sort函數“應輸入 2 個參數,卻提供了 3 個)
- 對vector<自定義類>使用std::find 和 std::find_if 算法