方式一:shared_ptr<string> pTom{new string("tom")}; 方式二:shared_ptr<string> pTom; pTom.reset(new string("tom")); 方式三:shared_ptr<string> pTom = make_shared<string>("tom"); 推荐:使用方式三,更快(一次复制),更安全 使用 shared_ptr<string> pTom = make_shared<string>("tom");...
std::shared_ptr 也可以用来管理动态分配的数组,但需要注意使用 std::shared_ptr 的数组特化。 #include <iostream> #include <memory> void example() { // 使用 std::shared_ptr 管理动态分配的数组 std::shared_ptr<int[]> ptr(new int[3]{1, 2, 3}); std::cout << "Array: "; for (int ...
std::shared_ptr<int> sp(newint[10], std::default_delete<int[]>()); 也可以使用一下的lambda表达式来自定义删除函数 std::shared_ptr<int> sp(newint[10], [](int*p) {delete[] p; }); 实际上,除非需要共享目标,否则unique_ptr更适合使用数组: std::unique_ptr<int[]> up(newint[10]);/...
std::shared_ptr<MyClass> ptr1 = std::make_shared<MyClass>(42); // 访问对象的方法 std::cout << "Value: " << ptr1->GetValue() << std::endl; // 创建另一个 shared_ptr,共享 ptr1 所指向的对象 std::shared_ptr<MyClass> ptr2(ptr1); // 当 ptr1 和 ptr2 都离开作用域时,MyC...
默认情况下,std::shared_ptr会调用delete来清空内存。当使用new[] 分配内存时,需要调用delete[] 来释放内存,否则会有内存泄露。 但是在 C++11 中 std::default_delete可以解决这个问题。 // unique 申请数组内存std::unique_ptr<int[], std::default_delete<int[]>> ac1 = std::make_unique<int[]>(10...
std::shared_ptr 是一种智能指针,它能够记录多少个 shared_ptr 共同指向一个对象,从而消除显示的调用 delete,当引用计数变为零的时候就会将对象自动删除。 std::shared_ptr 可以通过 get() 方法来获取原始指针,通过 reset() 来减少一个引用计数, 并通过use_count()来查看一个对象的引用计数。例如: ...
不同于std::shared_ptr构造函数,std::allocate_shared不接受另外的自定义删除器:它用提供的分配器来进行控制块和T对象的析构,及其共享内存块的解分配。 std::shared_ptr支持数组类型(从 C++17 起),但std::allocate_shared不支持。boost::allocate_shared支持此功能。
std::shared_ptr 是一种通过指针保持对象共享所有权的智能指针。多个 shared_ptr 对象可持有同一对象。下列情况之一出现时销毁对象并解分配其内存: 最后剩下的持有对象的 shared_ptr 被销毁; 最后剩下的持有对象的 shared_ptr 被通过 operator= 或reset() 赋值为另一指针。 用delete 表达式或在构造期间提供给...
share_ptr没有release接口。 classA{public:A(inta):m_a(a){std::cout<<"contruct:"<<m_a<<endl;}~A(){std::cout<<"destruct:"<<m_a<<endl;}intm_a;};intfunc(){std::shared_ptr<A>sp1;A*p=newA(1);sp1.reset(p);//A(1)这个对象(这片内存)引用计数+1sp1.reset(newA(2));//旧对...
std::shared_ptr⼤概总结有以下⼏点:(1) 智能指针主要的⽤途就是⽅便资源的管理,⾃动释放没有指针引⽤的资源。(2) 使⽤引⽤计数来标识是否有多余指针指向该资源。(注意,shart_ptr本⾝指针会占1个引⽤)(3) 在赋值操作中, 原来资源的引⽤计数会减⼀,新指向的资源引⽤计数会加⼀...