您的位置:首页 > 大数据 > 人工智能

指针容器: boost::ptr_vector ptr_container

2013-09-08 16:21 423 查看
在你见过 Boost C++ 库的各种智能指针之后,应该能够编写安全的代码,来使用动态分配的对象和数组。多数时候,这些对象要存储在容器里——如上所述——使用 boost::shared_ptr 和 boost::shared_array 这就相当简单了。
#include <boost/shared_ptr.hpp>
#include <vector>
int main()
{
std::vector<boost::shared_ptr<int> > v;
v.push_back(boost::shared_ptr<int>(new int(1)));
v.push_back(boost::shared_ptr<int>(new int(2)));
}


上面例子中的代码当然是正确的,智能指针确实可以这样用,然而因为某些原因,实际情况中并不这么用。 第一,反复声明 boost::shared_ptr 需要更多的输入。 其次,将 boost::shared_ptr拷进,拷出,或者在容器内部做拷贝,需要频繁的增加或者减少内部引用计数,这肯定效率不高。 由于这些原因,Boost C++ 库提供了指针容器
专门用来管理动态分配的对象。
#include <boost/ptr_container/ptr_vector.hpp>
int main()
{
boost::ptr_vector<int> v;
v.push_back(new int(1));
v.push_back(new int(2));
}


boost::ptr_vector 类的定义在 boost/ptr_container/ptr_vector.hpp里,它跟前一个例子中用 boost::shared_ptr 模板参数来初始化的容器具有相同的工作方式。 boost::ptr_vector 专门用于动态分配的对象,它使用起来更容易也更高效。 boost::ptr_vector 独占它所包含的对象,因而容器之外的共享指针不能共享所有权,这跟 std::vector<boost::shared_ptr<int> >
相反。
除了 boost::ptr_vector之外,专门用于管理动态分配对象的容器还包括:boost::ptr_deque, boost::ptr_list, boost::ptr_set, boost::ptr_map, boost::ptr_unordered_set 和 boost::ptr_unordered_map。这些容器等价于C++标准里提供的那些。最后两个容器对应于std::unordered_set和 std::unordered_map,它们作为技术报告1的一部分加入 C++ 标准。 如果所使用的
C++ 标准实现不支持技术报告1的话,还可以使用 Boost C++ 库里实现的 boost::unordered_set 和 boost::unordered_map。

boost 指针容器ptr_container之内存泄漏  

[cpp]
view plaincopyprint?

// shared_ptr.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <boost/ptr_container/ptr_container.hpp>
#define _crtdbg_map_alloc
#include "stdlib.h"
#include "crtdbg.h"

class CMan
{
public:
CMan()
{
printf("construct/n");
}
~CMan()
{
printf("deconstruct/n");
}
protected:
private:
};

int _tmain(int argc, _TCHAR* argv[])
{
{
boost::ptr_vector<CMan> listMan;

CMan *p1 = new CMan();
listMan.push_back(p1);

//char * sz = new char[32];
}

_CrtDumpMemoryLeaks();

//system("pause");

return 0;
}

// shared_ptr.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <boost/ptr_container/ptr_container.hpp>
#define _crtdbg_map_alloc
#include "stdlib.h"
#include "crtdbg.h"

class CMan
{
public:
CMan()
{
printf("construct/n");
}
~CMan()
{
printf("deconstruct/n");
}
protected:
private:
};

int _tmain(int argc, _TCHAR* argv[])
{
{
boost::ptr_vector<CMan> listMan;

CMan *p1 = new CMan();
listMan.push_back(p1);

//char * sz = new char[32];
}

_CrtDumpMemoryLeaks();

//system("pause");

return 0;
}

很多野文都提到,放心使用boost的指针容器:容器在析构的时候,会自动清理指针。

那么有认真测试过内存泄漏的问题吗?自己动手来测试下吧。

我使用_CrtDumpMemoryLeaks简单的检测方法。

结果,对比代码中的new char,ptr_vector确实没有泄漏。

运行代码也会发现,容器析构的时候,其指针成员的析构也会执行。

这下我们可以方向使用boost指针容器了吧。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: