最近项目中使用boost库的智能指针,感觉智能指针还是蛮强大的,在此贴出自己学习过程中编写的测试代码,以供其他想了解boost智能指针的朋友参考,有讲得不正确之处欢迎指出讨论。当然,使用boost智能指针首先要编译boost库,具体方法可以网上查询,在此不再赘述。
智能指针能够使C++的开发简单化,主要是它能够自动管理内存的释放,而且能够做更多的事情,即使用智能指针,则可以再代码中new了之后不用delete,智能指针自己会帮助你管理内存资源的释放。
Boost库的智能指针有很多种,下面通过示例代码来说明其中shared_ptr的使用方法。
// 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) 使用智能指针出现循环引用的情况,即两个类互相含有对方类对象的智能指针。这时可使用weak_ptr来解决。
原文地址:http://ticktick.blog.51cto.com/823160/196765
分享到:
相关推荐
C++中的智能指针首先出现在“准”标准库boost中。 随着使用的人越来越多,为了让开发人员更方便、更安全的使用动态内存,C++11也引入了智能指针来管理动态对象。 在新标准中,主要提供了shared_ptr、unique_ptr、...
scoped_ptrboost::scoped_ptr和std::auto_ptr非常类似,是一个简单的智能指针,它能够保证在离开作用域后对象被自动释放。下列代码演示了该指针的基本应用: 代码如下:#include <string>#include <iostream>#...
shared_ptr是一种智能指针(smart pointer)。shared_ptr的作用有如同指针,但会记录有多少个shared_ptrs共同指向一个对象。 这便是所谓的引用计数(reference counting)。一旦最后一个这样的指针被销毁,也就是...
shared_ptr在boost中地位相当重要,其行为接近原始指针,但又比指针更加安全,甚至还能提供基本的线程安全保证。它基本上解决了在使用c++开发过程中不可避免的使用指针而遇到的许多问题,常见的毫无疑问是内存泄漏和...
显然,许多人不喜欢标准std :: enable_... boost库也可以这样做,但是它不允许在析构函数中创建shared_ptrs,并且它不提供release()方法来获取所包含指针的所有权。 但是,不利的一面是,它还没有成为线程安全的。
#include <boost/shared_ptr.hpp> class CBase: public boost::enable_shared_from_this<CBase> { public: virtual void f(){}//必须有个虚函数才能向上向下转换。 } typedef boost::shared_ptr<CBase> CBasePtr; ...
一、简介 由于 C++ 语言没有自动...包括:std::auto_ptr、boost::scoped_ptr、boost::shared_ptr、boost::scoped_array、boost::shared_array、boost::weak_ptr、boost:: intrusive_ptr。你可能会想,如此多的智能指
本文通过实例详细阐述了C++关于智能指针的概念及用法,有助于读者加深对智能指针的理解。...包括:std::auto_ptr、boost::scoped_ptr、boost::shared_ptr、boost::scoped_array、boost::shared_array、boost::
本代码为C++类库boost实现的示例源码,使用VS2015编译,代码中有相关的注释,如发现有问题,请不吝指教,谢谢!
介绍之前先上⼀张别⼈的表格,来源:,这是c++11中的智能指针与boost库中的⽐较,原本boost就是为完善auto_ptr搞得这些,现在 c++11有了,也就不需要再⽤咯。 2.unique_ptr C++11引⼊了许多便捷的功能,其中也包括...
C++11 下使用 Boost.Serialization 库实现智能指针的序列化
消息(std::string包装)不再用boost::shared_ptr包装,之前有过度使用智能指针之嫌。效率上,std::string如果支持引用记数,或者编译器支持std::move语义,是没有损失的(因为也不存在内存的拷贝,反而省了智能指针...
消息(std::string包装)不再用boost::shared_ptr包装,之前有过度使用智能指针之嫌。效率上,std::string如果支持引用记数,或者编译器支持std::move语义,是没有损失的(因为也不存在内存的拷贝,反而省了智能指针...
C++ 中有四种智能指针:auto_pt、unique_ptr、shared_ptr、weak_ptr 其中后三个是 C++11 ⽀持,第⼀个已经被 C++11 弃⽤且被 unique_prt 代替,不推荐使⽤。下⽂将对其逐个说明。 std::auto_ptr 在这个年代讨论 std...
boost 是 C++ 所谓的“准标准库”,是 C++ 标准库的实验场,其所提供的智能指针 shared_ptr 已经被收入 C++ 的新标准。boost 包含大量设计精巧、功能强大、性能卓越的组件,如智能指针、函数对象、lambda表达式、...
* 新的ref_ptr函数,提供了更大的灵活性,以及osg::Referenced与boost::shared_ptr指针的互用性; * 改进了ImageSequence类的实现; * 新的osg3cpp实用程序,用于将GLSL着色器文件转换为可以直接编译到程序中的....
现代的C/C++类库一般会提供智能指针来作为内存管理的折中方案,比如STL的auto_ptr,Boost的Smart_ptr库,QT的QPointer家族,甚至是基于C语言构建的GTK+也通过引用计数来实现类似的功能。Linux内核是如何解决这个问题...
如何避免这种竞态条件是 C++ 多线程编程面临的基本问题,可以借助 boost 的 shared_ptr 和 weak_ptr 完美解决。这也是实现线程安全的 Observer 模式的必备技术。 本文源自陈硕在 2009 年 12 月上海 C++ 技术大会的一...
如何避免这种竞态条件是 C++ 多线程编程面临的基本问题,可以借助 boost 的 shared_ptr 和 weak_ptr 完美解决。这也是实现线程安全的 Observer 模式的必备技术。 本文源自我在 2009 年 12 月上海 C++ 技术大会的一场...