C++ 中boost::share_ptr智能指针的使用方法

时间:2022-12-03 11:43:34

C++ 中boost::share_ptr智能指针的使用方法

最近项目中使用boost库的智能指针,感觉智能指针还是蛮强大的,在此贴出自己学习过程中编写的测试代码,以供其他想了解boost智能指针的朋友参考,有讲得不正确之处欢迎指出讨论。当然,使用boost智能指针首先要编译boost库,具体方法可以网上查询,在此不再赘述。

智能指针能够使C++的开发简单化,主要是它能够自动管理内存的释放,而且能够做更多的事情,即使用智能指针,则可以再代码中new了之后不用delete,智能指针自己会帮助你管理内存资源的释放。

Boost库的智能指针有很多种,下面通过示例代码来说明其中share_ptr的使用方法。    

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
/ test.cpp : Defines the entry point for the console application.
#include "stdafx.h"
#include <iostream>
#include <boost/shared_ptr.hpp>
#include <vector>
 
/** 测试类  */
class CTest
{
public:
   
    /**  构造函数 */
    CTest(int m)
    {
        m_member = m;
 
        /** 申请空间 */
        m_pname = new char[2];
    }
    /** 析构函数 */
    ~CTest()
    {
        delete m_pname;
    }
 
    /** 成员函数 */
    int getMember()
    {
        return m_member;
    }
 
private:
 
    /** 数据成员 */
    int m_member;
    char * m_pname;
   
};
 
int _tmain(int argc, _TCHAR* argv[])
{
 
/** 示例代码【1】 */
 
    /** boost::shared_ptr智能指针含有一个引用计数器 */
    /** 引用指针计数器记录有多少个引用指针指向同一个对象,如果最后一个引用指针被销毁的时候,那么就销毁对象本身。 */
 
    /** 使用智能指针创建一个对象 */
    /** 注意: 智能指针不支持直接 new 例如: boost::shared_ptr<CTest> pTemp = new CTest(2) 是错误的 */
    boost::shared_ptr<CTest> pTemp(new CTest(10));
 
    /** 创建一个新的智能指针也指向新创建的CTest对象 */
    /** 智能指针支持等号操作 */
    boost::shared_ptr<CTest> pSecond = pTemp;
 
    /** 通过智能指针访问该对象 */
    std::cout << pTemp->getMember() << std::endl;
 
    /** 让第一个智能指针为空,不再指向该对象,注意,智能指针不能使用 pTemp = NULL */
    pTemp.reset();
 
    /** 让第二个智能指针也为空,这时该CTest对象已经没有智能指针指向它了,会自动析构 */
    pSecond.reset();
 
/** 示例代码【2】 */
 
    /** 将一个普通的指针转换为智能指针 */
 
    /** 创建一个普通的指针,new一个对象 */
    CTest * pATest = new CTest(100);
    /** 转换为智能指针 */
    boost::shared_ptr<CTest> pShareTest(pATest);
 
    /** 智能指针会自动管理创建的CTest对象,不允许再进行delete,否则程序会挂掉 */
    delete pATest;
 
    /** 让智能指针为空,则对象会被自动析构 */
    pShareTest.reset();
 
 
/** 示例代码【3】 */
 
    /** 创建一个容器存放智能指针 */
    /** 这里需要注意: 两个“ > ” 不要写到一起了,否则会产生 >> 运算符重载  */
    std::vector<boost::shared_ptr<CTest> > vec;
 
    /** 创建一个临时的CTest对象,存放到上面的容器 */
 
    {
        /** 使用智能指针创建一个对象 */
        boost::shared_ptr<CTest> pTemp(new CTest(2));
 
        /** 添加到容器中 */
        vec.push_back(pTemp);
 
        /** 离开大括号,则pTemp析构,于是只有容器中的指针指向了新创建的CTest */
    }
 
    /** 让vector迭代器指向刚刚push_back到容器中的智能指针 */
    std::vector<boost::shared_ptr<CTest> >::iterator itor = vec.begin();
 
    /** 访问智能指针, (*itor)即为智能指针对象,指向了刚才创建的CTest,通过 -> 方法访问CTest对象  */
    std::cout << (*itor)->getMember()<<std::endl;
 
 
    /** 清空容器,在容器被清空时,容器中的智能指针被删除,
        由于此时已经没有智能指针指向该对象,故该CTest对象会自动析构 */
    vec.clear();
 
    int temp;
    std::cin >> temp;
 
 
    return 0;
}
 
/** 使用智能指针需要注意的地方 */
 
// 1. 智能指针其实是一种类对象,并不是简单的指针,故当智能指针包含另一个类的对象时,
//    需要包含另一个类的头文件,而不能简单的使用前向引用声明
// eg: CMyClass.h文件
 
 #include "CTest.h"
 /** 不能简单地使用前向引用声明,必须包含头文件 */
 // 前向引用声明 class CTest
 
class CMyClass
{
public:
 
private:
    boost::shared_ptr<CTest> m_pTest;
 
};
 
// 2. shared_ptr 是线程安全的
 
// 3. 使用智能指针出现循环引用的情况
// 即两个类互相含有对方类对象的智能指针

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

原文链接:http://ticktick.blog.51cto.com/823160/196765