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

2025-05-27 0 95

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

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

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

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 C++ 中boost::share_ptr智能指针的使用方法 https://www.kuaiidc.com/72827.html

相关文章

发表评论
暂无评论