智能指针的使用
C++中的智能指针实现是通过一个类来管理实际上的指针
,这个类要具备指针的基本操作。
一.shared_ptr
1.创建一个shared_ptr
std::shared_ptr<int> ptra = std::make_shared<int>(20);
std::shared_ptr<int> ptra1(new int(20));
二者的区别:
前者std::make_shared
一次性为int
对象和用于引用计数的数据都分配了内存;后者new操作符只是为int分配了内存,引用计数会在构造函数中再做处理。
注意: 后者千万不能写成:
std::shared_ptr<int> ptra1 = new int(20);
因为你将一个int指针赋值给一个类对象,肯定不行。其实很好理解,这种情况下我们要调用的是构造函数,而不是赋值构造。
而前者写成:
std::shared_ptr<int> ptra(std::make_shared<int>(20));
也是可以的,均是调用拷贝构造函数。
2.shared_ptr的常用成员函数
为方便说明,我生成下面这样的一个shared_ptr类,表格中的说明均基于此。
string* ps = new string("hello");
shared_ptr<string> p(ps);
成员函数 | 说明 |
---|---|
p.use_count() | 返回和p共享的类对象个数 |
p.unique() | 若p.use_count() == 1 时,返回true |
*p | 等同 *ps,为hello |
p->length() | 等同ps->length(),返回string对象的长度 |
p | 若p指向一个对象,则返回true |
测试代码如下:
#include <iostream>
#include <string>
#include <memory>
using namespace std;
int main()
{
string s = "hello";
//"生成两个指针:"
std::shared_ptr<string> ptrs = std::make_shared<string>(s);
std::shared_ptr<string> ptrs2(ptrs); //拷贝构造,此时ptrs和ptrs2共同"指向"a的内存空间
// "打印引用计数:"
std::cout << ptrs.use_count() << std::endl;//引用计数为2
std::cout << ptrs2.use_count() << std::endl;//引用计数为2
//"改变ptrs2的指向:
ptrs2 = std::make_shared<string>("world");//改变ptra2的指向
//"打印此时的引用计数:"
std::cout << ptrs.use_count() << std::endl;//引用计数为1
std::cout << ptrs2.use_count() << std::endl;//引用计数为1
//"unique使用:"
if (ptrs.unique())
cout << "ptrs的引用计数为1" << endl