智能指针(shared_ptr、unique_ptr、weak_ptr)的使用

智能指针的使用

  • 一.shared_ptr
    • 1.创建一个shared_ptr
    • 2.shared_ptr的常用成员函数
      • reset成员函数的使用
    • 3.==注意事项==
  • 二.unique_ptr
    • 1.unique_ptr区别于shared_ptr
    • 2.unique_ptr的成员函数与std::move()
    • 3. 函数返回unique_ptr
  • 三.weak_ptr
    • 1. 使用weak_ptr解决循环引用的问题

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 
#include 
#include 

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 

你可能感兴趣的:(C/C++,C++,智能指针)