智慧指標(auto_ptr 和 shared_ptr)
轉自:http://www.cppblog.com/expter/archive/2009/03/29/78270.html
都是這周看書以及程式碼的總結:
Stl 中 auto_ptr只是眾多可能的智慧指標之一,auto_ptr所做的事情,就是動態分配物件以及當物件不再需要時自動執行清理。
這裡是一個簡單的程式碼示例,如果沒有auto_ptr,
2{
3
4 while (data) // 如果還有資料
5 {
6 ALA *pa = readALAData(data); // 取出下一個資料
7 pa->DealProcessAdoption(data); // 處理
8
9 delete pa; // 釋放資源
10 }
11 return;
12}
如果在DealProcessAdoption有一個exception,會發生什麼事情,因為ProcessAdoption不能捕獲他,所以這段程式碼很危險,所以DealProcessAdoption後面的程式碼可能會跳過,造成記憶體洩露。
如果利用try catch去捕獲他,會搞得程式碼很亂,又缺少美觀性。
所以Stl提供了一個智慧指標來解決這個問題,我們可以先模擬實現一個智慧指標的類實現。
2template<typename Type>
3class auto_ptr
4{
5public:
6 auto_ptr(T *p =NULL) :Ptr(p)
7 { }
8 ~auto_ptr()
9 {
10 delete Ptr;
11 }
12private:
13 Type *Ptr;
14};
15
16
17void ProcessAdoption(istream &data)
18{
19
20 while (data) // 如果還有資料
21 {
22 auto_ptr<ALA> pa(readALADara(data));
23 pa->DealProcessAdoption(data);
24 }
25 return;
26}
這個版本和原先版本的差異只有二處,
第一pa是一智慧指標的物件,不是ALA*
第二不用自己去釋放delete
然後我看到Effective STL的條款
8:永不建立auto_ptr的容器
關於此可以看的Effective STL的條款8
因為auto_ptr並不是完美無缺的,它的確很方便,但也有缺陷,在使用時要注意避免。首先,不要將auto_ptr物件作為STL容器的元素。C++標準明確禁止這樣做,否則可能會碰到不可預見的結果
auto_ptr的另一個缺陷是將陣列作為auto_ptr的引數: auto_ptr<char> pstr (new char[12] ); //陣列;為定義
然後釋放資源的時候不知道到底是利用delete pstr,還是 delete[] pstr;
然後收集了關於auto_ptr的幾種注意事項:
1、auto_ptr不能共享所有權。
2、auto_ptr不能指向陣列
3、auto_ptr不能作為容器的成員。
4、不能通過賦值操作來初始化auto_ptr
std::auto_ptr<int> p(new int(42)); //OK
std::auto_ptr<int> p = new int(42); //ERROR
這是因為auto_ptr 的建構函式被定義為了explicit
5、不要把auto_ptr放入容器
然後筆者從而推薦的是boost的shared_ptr,然後看完shared_ptr關於智慧指標的介紹與例子。
5種針對auto_ptr不足的指標如下:需要詳細瞭解可以去檢視相當文件,與測試新程式碼。
scoped_ptr | <boost/scoped_ptr.hpp> | 簡單的單一物件的唯一所有權。不可拷貝。 |
scoped_array | <boost/scoped_array.hpp> | 簡單的陣列的唯一所有權。不可拷貝。 |
shared_ptr | <boost/shared_ptr.hpp> | 在多個指標間共享的物件所有權。 |
shared_array | <boost/shared_array.hpp> | 在多個指標間共享的陣列所有權。 |
weak_ptr | <boost/weak_ptr.hpp> | 一個屬於 shared_ptr 的物件的無所有權的觀察者。 |
intrusive_ptr | <boost/intrusive_ptr.hpp> | 帶有一個侵入式引用計數的物件的共享所有權。 |
1. shared_ptr是Boost庫所提供的一個智慧指標的實現,shared_ptr就是為了解決auto_ptr在物件所有權上的侷限性(auto_ptr是獨佔的),在使用引用計數的機制上提供了可以共享所有權的智慧指標.
2. shared_ptr比auto_ptr更安全
3. shared_ptr是可以拷貝和賦值的,拷貝行為也是等價的,並且可以被比較,這意味這它可被放入標準庫的一般容器(vector,list)和關聯容器中(map)。
關於shared_ptr的使用其實和auto_ptr差不多,只是實現上有差別,關於shared_ptr的定義就不貼程式碼了,以為內開源,可以網上找
1、shared_ptr<T> p(new Y);
要了解更多關於auto_ptr的資訊,可以檢視more effective c++ 的p158頁條款28
要了解shared_ptr 類别範本資訊,可以檢視boost 1.37.0中文文件,而且支援陣列的shared_array 類别範本
posted on 2009-03-29 15:50 expter 閱讀(15483) 評論(2) 編輯 收藏引用 所屬分類:其他學習筆記 、演算法與資料結構
相關文章
- auto_ptr 智慧指標指標
- c++ auto_ptr 智慧指標C++指標
- 【C++智慧指標 auto_ptr】C++指標
- 智慧指標之手撕共享指標shared_ptr指標
- 正確使用auto_ptr智慧指標指標
- c++ auto_ptr類 智慧指標C++指標
- C/C++——跟我重寫智慧指標auto_ptr模版類C++指標
- C++ 智慧指標詳解: std::unique_ptr 和 std::shared_ptrC++指標
- C++基礎回顧4——智慧指標shared_ptrC++指標
- 智慧指標思想實踐(std::unique_ptr, std::shared_ptr)指標
- C++智慧指標之shared_ptr與右值引用(詳細)C++指標
- C++14 智慧指標unique_ptr、shared_ptr、weak_ptrC++指標
- c++中關於智慧指標std::tr1::shared_ptr的用法C++指標
- 智慧指標指標
- [CPP] 智慧指標指標
- 指標常量和常量指標指標
- 智慧指標-使用、避坑和實現指標
- 什麼是智慧指標?為什麼要用智慧指標?指標
- openfoam 智慧指標探索指標
- vtk智慧指標指標
- 智慧指標學習指標
- 【c++】智慧指標C++指標
- C++智慧指標C++指標
- 關於指標傳遞和指標的指標指標
- 詳解 常量指標和指標常量指標
- 陣列指標和指標陣列陣列指標
- 指標函式 和 函式指標指標函式
- C語言指標(三):陣列指標和字串指標C語言指標陣列字串
- 指標和常量指標
- UE4 智慧指標指標
- 批註:智慧指標分析指標
- C++11 智慧指標C++指標
- 「C++」理解智慧指標C++指標
- SMART POINTER(智慧指標) (轉)指標
- 智慧指標用法學習指標
- 指向常量資料的指標和常量指標指標
- 指標+AI:邁向智慧化,讓指標應用更高效指標AI
- C++ 用智慧指標這樣包裝 this 指標是否可行C++指標