共享指针

这个智能指针命名为boost::shared_ptr,定义在boost/shared_ptr.hpp里。智能指针boost::shared_ptr基本上类似于boost::scoped_ptr。关键不同之处在于boost::shared_ptr不一定要独占一个对象。它可以和其他boost::shared_ptr类型的智能指针共享所有权。在这种情况下,当引用对象的最后一个智能指针销毁后,对象才会被释放。

因为所有权可以在boost::shared_ptr之间共享,任何一个共享指针都可以被复制,这跟boost::scoped_ptr是不同的。这样就可以在标准容器里存储智能指针了--你不能在标准容器中存储std::auto_ptr,因为它们在拷贝的时候传递了所有权。

 

 1 #include <iostream>
 2 #include <algorithm>
 3 #include <vector>
 4 #include <boost/shared_ptr.hpp>
 5 
 6 void show(boost::shared_ptr<int>p)
 7 {
 8     std::cout << *p << std::endl;
 9 }
10 
11 void main()
12 {
13     std::vector<boost::shared_ptr<int>>v;
14 
15     boost::shared_ptr<int>p1(new int(11));
16     boost::shared_ptr<int>p2(new int(12));
17     boost::shared_ptr<int>p3(new int(13));
18 
19     v.push_back(p1);
20     v.push_back(p2);
21     v.push_back(p3);
22     
23     for_each(v.begin(), v.end(), show);
24 }

 

使用boost::shared_ptr的类型初始化新对象,是浅拷贝

 

 1 #include <iostream>
 2 #include <boost/shared_ptr.hpp>
 3 
 4 class runclass
 5 {
 6 public:
 7     int i = 0;
 8 public:
 9     runclass(int num) :i(num)
10     {
11         std::cout << "i creator " << i << std::endl;
12     }
13     ~runclass()
14     {
15         std::cout << "i delete " << i << std::endl;
16     }
17     void print()
18     {
19         std::cout << "i=" << i << std::endl;
20     }
21 };
22 
23 void show(boost::shared_ptr<int>p)
24 {
25     std::cout << *p << std::endl;
26 }
27 
28 void main()
29 {
30     boost::shared_ptr<runclass>p1(new runclass(10));//有调用构造函数
31 
32     boost::shared_ptr<runclass>p2(p1);//浅拷贝,没有调用构造函数
33     boost::shared_ptr<runclass>p3(p1);//浅拷贝,没有调用构造函数
34 
35     p1.reset(new runclass(12));//有调用构造函数
36 
37     p1->print();
38     p2->print();
39     p3->print();
40 }