Shared_pointer 表现出与我在教科书上读到的不同的行为
Shared_pointer showing different behaviour than the one i read in text book
所以我正在尝试加深对 shared_ptr 的理解,如果多个共享 ptr 指向同一资源共享指针,则可以处理在最后一个指针指向资源被破坏。
这是我的示例代码:
#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
)正在处理它。它“认为”你正在传递你刚刚分配的东西。因此,它们都尝试释放同一个指针,导致您观察到的“双重释放”错误。
共享指针管理资源后,尽量避免与裸指针打交道,绝对不要传递给另一个。
所以我正在尝试加深对 shared_ptr 的理解,如果多个共享 ptr 指向同一资源共享指针,则可以处理在最后一个指针指向资源被破坏。
这是我的示例代码:
#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
)正在处理它。它“认为”你正在传递你刚刚分配的东西。因此,它们都尝试释放同一个指针,导致您观察到的“双重释放”错误。
共享指针管理资源后,尽量避免与裸指针打交道,绝对不要传递给另一个。