boost::share_ptr智能指针使用示例

本文详细介绍了Boost库中的智能指针概念及share_ptr的具体用法,包括如何创建、使用智能指针,以及智能指针与普通指针之间的转换,并演示了在容器中使用智能指针的示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近项目中使用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

140

141

142

143

/ 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. 使用智能指针出现循环引用的情况

// 即两个类互相含有对方类对象的智能指针

// 看下面这一篇文章Boost智能指针——weak_ptr

 

网址: 

http://www.cnblogs.com/TianFang/archive/2008/09/20/1294590.html

 

 

 

原文转自:乐搏学院http://www.learnbo.com/front/article/cmsIndex

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值