c++ - Shared_pointer 显示出与我在教科书中读到的行为不同的行为

标签 c++ stl smart-pointers

因此,我正在尝试加深对 shared_ptr 的理解,如果多个共享 ptr 指向同一资源共享指针,则可以处理在销毁指向资源的最后一个指针之前不应调用 destrcutor 的情况。

这是我的示例代码:

#include <iostream>
#include <memory>
class A {
public:
    A(int num) {
        std::cout << "cons A\n";
    }
    ~A() {
        std::cout << "dis A\n";
    }
};

int main() {
    std::shared_ptr<A> ptr(new A(12));
    {
        std::cout << "Inside Scope \n";
        std::shared_ptr<A> ptr1 = ptr;
        std::cout << "Outside Scope \n";
    }
    std::shared_ptr<A> ptr2(ptr.get());
    std::cout << ptr << std::endl;
}

抛出异常的输出如下所示

cons A
Inside Scope 
Outside Scope 
dis A
dis A
free(): double free detected in tcache 2

任何人都可以解释这种行为还是我误读了什么?提前致谢。

最佳答案

问题出在你的线路上

std::shared_ptr<A> ptr2(ptr.get());

这不是共享指针的使用方式。相反,用类似的东西替换它

std::shared_ptr<A> ptr2{ptr};

std::shared_ptr<A> ptr2 = ptr;

(此外,正如 Den-Jason 在评论中指出的那样,您应该更喜欢使用 std::make_shared 。)


当您将裸指针传递给 ptr2 时,它无法“知道”另一个共享指针(在本例中为 ptr)正在处理它。它“认为”你正在传递你刚刚分配的东西。因此,它们都尝试释放同一个指针,导致您观察到的“双重释放”错误。

一旦共享指针管理了一个资源,你应该尽可能避免与裸指针打交道,绝对不要将它传递给另一个。

关于c++ - Shared_pointer 显示出与我在教科书中读到的行为不同的行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65505629/

相关文章:

c++ - WTSQuerySessionInformation 返回空字符串

c++ - 初始化模板数组

c++ - 如何调试 STL/C++ 的 GCC/LD 链接过程

c++ - 删除元素时 map 迭代器如何失效?

C++对`vtable的 undefined reference

c++ - 为什么我在 Visual Studio 和 Qt 上编译相同的代码,却得到不同的结果?

c# - protobuf-net 到 .proto 生成枚举冲突?

c++ - shared_ptr 的自定义删除器的附加参数

c++ - 与指针 vector 一起使用的最佳智能指针是什么

c++ - 输出 cout 是感叹号。 C++