C++(11):make_shared

智能指针shared_ptr有两种初始化的方式:

shared_ptr sp1 (new int(10));            //通过new构造数据对象
shared_ptr sp2 = make_shared(10);  //通过make_shared构造数据对象

之前看过一些相关的文档,描述了这两种方式的不同,主要的区别是说通过new构造的时候:

  • 通过new构造,涉及到两次内存分配,第一次是通过new为数据对象分配内存,即上方的new int(10),第二次是构造一个shared_ptr的管理对象,管理对象记录了强引用(shared_ptr)计数,弱引用(weak_ptr)计数,以及数据对象(new int(10))的地址。当管理对象发现强引用计数为0时,释放数据对象的内存,当管理对象发现弱引用计数为0时,释放管理对象的内存。

C++(11):make_shared_第1张图片

  •  通过make_shared构造,只分配一次内存,这一块内存里既包括管理对象,也包括数据对象。由于是在一块内存里,所以即使强引用计数已被清零,但如果弱引用计数还没有清零,那么也无法释放这一块内存,直到弱引用计数清零时,这一块内存(包括管理对象和数据对象)才能被释放。

C++(11):make_shared_第2张图片

 通过以下程序进行验证:

#include 
#include 
using namespace std;

class A{
public:
	A()
	{
		cout<<"Construct A, this addr:"<
void shared_ptr_valid(weak_ptr &wp)
{
	shared_ptr spCheck = wp.lock();
	if(spCheck == nullptr)
	{
		cout<<"shared_ptr is invalid"< wp;
	{
		cout<<"pos 1"< sp1(new A);
		cout<<"pos 2 sp1 addr:"<<&sp1<<" ref to:"<<*sp1< sp2 = sp1;
		cout<<"pos 3 sp2 addr:"<<&sp2<<" ref to:"<<*sp2< wp;
	{
		cout<<"pos a"< sp1 = make_shared();
		cout<<"pos b sp1 addr:"<<&sp1<<" ref to:"<<*sp1< sp2 = sp1;
		cout<<"pos c sp2 addr:"<<&sp2<<" ref to:"<<*sp2<

你可能感兴趣的:(#,C++11,c++)