智能指针shared_ptr有两种初始化的方式:
shared_ptr<int> sp1 (new int(10)); //通过new构造数据对象
shared_ptr<int> sp2 = make_shared<int>(10); //通过make_shared构造数据对象
之前看过一些相关的文档,描述了这两种方式的不同,主要的区别是说通过new构造的时候:
-
通过new构造,涉及到两次内存分配,第一次是通过new为数据对象分配内存,即上方的new int(10),第二次是构造一个shared_ptr的管理对象,管理对象记录了强引用(shared_ptr)计数,弱引用(weak_ptr)计数,以及数据对象(new int(10))的地址。当管理对象发现强引用计数为0时,释放数据对象的内存,当管理对象发现弱引用计数为0时,释放管理对象的内存。
-
通过make_shared构造,只分配一次内存,这一块内存里既包括管理对象,也包括数据对象。由于是在一块内存里,所以即使强引用计数已被清零,但如果弱引用计数还没有清零,那么也无法释放这一块内存,直到弱引用计数清零时,这一块内存(包括管理对象和数据对象)才能被释放。