在你见过 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之内存泄漏  

  1. // shared_ptr.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #include <boost/ptr_container/ptr_container.hpp>
  5. #define _crtdbg_map_alloc
  6. #include "stdlib.h"
  7. #include "crtdbg.h"
  8. class CMan
  9. {
  10. public:
  11. CMan()
  12. {
  13. printf("construct/n");
  14. }
  15. ~CMan()
  16. {
  17. printf("deconstruct/n");
  18. }
  19. protected:
  20. private:
  21. };
  22. int _tmain(int argc, _TCHAR* argv[])
  23. {
  24. {
  25. boost::ptr_vector<CMan> listMan;
  26. CMan *p1 = new CMan();
  27. listMan.push_back(p1);
  28. //char * sz = new char[32];
  29. }
  30. _CrtDumpMemoryLeaks();
  31. //system("pause");
  32. return 0;
  33. }

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

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

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

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

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

这下我们可以方向使用boost指针容器了吧。


Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐