BOOST库shared_ptr在标准容器中的应用

有两种方法可以将shared_ptr应用于于标准容器(或者容器适配器等其他容器)。

      一种用法是将容器作为shared_ptr管理的对象,如shared_ptr<vector<T>>,使容器可以安全的被共享,用法与普通shared_ptr差不多,这里不再讨论。

     另外一种用法是shared_ptr作为容器的元素,如vector<shared_ptr<T>>,因为shared_ptr支持拷贝语义和比较操作,符合标准容器对元素的要求,所以可以在容器中安全的容纳元素的指针而不是拷贝。

标准容器不能容纳scoped_ptr,因为scoped_ptr不能拷贝和赋值。标准容器可以容纳原始指针,但是这样使得容器的功能减小,因为标准容器不能无法自动管理类型为指针的元素,必须编写其他代码来保证指针最终被正确的删除,这样通常麻烦而且容易出错。

储存shared_ptr的容器与存储原指针的容器功能几乎一样,但shared_ptr为程序员做了指针的管理工作,可以任意的使用shared_ptr而不用担心资源泄露问题。

下面代码展示shared_ptr在标准容器中的使用:


#include <iostream>
#include <vector>
#include <boost/make_shared.hpp>
#include <boost/shared_ptr.hpp>
using namespace std;
using namespace boost;


int main()
{
typedef vector<boost::shared_ptr<int>> vs;//一个持有shared_ptr的标准容器
vs v(10); // 声明有10个元素的容器
int i = 0;
for (auto pos = v.begin(); pos != v.end();++pos)
{
(*pos) =boost::make_shared<int>(++i); //使用工厂函数赋值
cout << *(*pos) << " "; //输出的值
}
cout << endl;

boost::shared_ptr<int> p = v[9];
*p = 100;
cout << *v[9] <<endl;

system("pause");
return 0;
}


这段代码需要注意的是operator[]用法,因为容器储存的是shared_prt,我们必须对迭代器使用一次解引用操作符*以获得shared_ptr,然后再对shared_prt使用解引用操作符*才能真正的操作到值。*(*pos)也可以直接的写成**pos,但是前者更清晰,后者理解起来有点难。


猜你喜欢

转载自blog.csdn.net/qq_36812406/article/details/78863408