std::shared_ptr是 C++ 标准库中的一种智能指针,允许多个指针共享管理同一个对象的生命周期。它通过引用计数(reference count)来记录有多少个指针指向同一个对象,当引用计数为零时,std::shared_ptr会自动释放对象,避免手动管理内存带来的风险。 #include<iostream> #include<memory> voidexample(){ std::shared_pt...
std::shared_ptr 是C++11 标准库中的智能指针类型,用于管理动态分配的对象。与传统指针不同,std::shared_ptr 自动管理内存,并在不再使用时自动释放对象,以避免内存泄漏。它是一种共享所有权的智能指针,即可以让多个 std::shared_ptr 指向同一个对象,并且会记录有多少个 std::shared_ptr 拥有该对象。 使用方法...
#include<iostream>#include<memory>intmain(){autop=std::shared_ptr<int>(newint(4));// int num{10};// auto p1 = std::shared_ptr<int>(p, &num);std::weak_ptr<int>wp1=p;autowp2=wp1;std::cout<<"wp1 use_count: "<<wp1.use_count()<<"\n"<<"p1: "<<*p<<"\n";return0;...
如上所说,当我们使用相同的原始指针rawPtr创建多个std::shared_ptr,这将导致多个智能指针认为它们各自拥有对象的所有权,这将导致在最终析构时多次删除同一个对象,从而产生未定义行为(通常是程序崩溃)。 如果在创建std::shared_ptr之后,原始指针rawPtr被用来访问或者删除对象,那么当std::shared_ptr的实例被销毁时,它...
与std::make_shared一起使用可以提高效率和减少内存碎片。 3. std::weak_ptr (C++11) 原理与特点: 提供对std::shared_ptr管理对象的弱引用,不增加引用计数。 可以检查所指向的对象是否仍然存活(未被删除)。 通过调用lock()方法临时获取一个可访问对象的shared_ptr,如果对象已被删除,则返回空shared_ptr。
std::shared_ptr 的类型转换通常发生在以下几种场景: 基类到派生类的转换:在面向对象编程中,经常需要将基类指针或引用转换为派生类指针或引用,以便访问派生类特有的成员。 不同类型指针之间的转换:在某些情况下,可能需要将 std::shared_ptr 指向的对象类型从一种类型转换为另一种类型。
std::shared_ptr是通过指针保持对象共享所有权的智能指针。多个shared_ptr对象可占有同一对象。下列情况之一出现时销毁对象并解分配其内存: 最后剩下的占有对象的shared_ptr被销毁; 最后剩下的占有对象的shared_ptr被通过operator=或reset()赋值为另一指针。
使用std::weak_ptr 打破循环引用 当两个对象相互持有对方的 shared_ptr 时,我们可以使用 std::weak_ptr 来解决循环引用的问题。std::weak_ptr 是一种弱引用,它可以指向由 shared_ptr 管理的对象,但并不会增加对象的引用计数。我们可以通过调用 std::weak_ptr 的 lock() 方法获得一个指向对象的 shared_ptr,...
(1)如果从std::shared_ptr获取原始指针(通过.get()方法),然后继续使用这个原始指针,即使所有std::shared_ptr都已释放资源,原始指针仍然存在,但它指向的对象已经被销毁。原始指针就变成了悬空指针。 std::shared_ptr<int> sp(new int(42)); int* rawPtr = sp.get(); // 获取原始指针 ...
std::shared_ptr<SharedClass>getShared(){ returnshared_from_this(); } }; intmain(){ // 创建shared_ptr autoptr1 = std::make_shared<SharedClass>(); { // 创建另一个指向同一对象的shared_ptr std::shared_ptr<SharedClass> ptr2 = ptr1; ...