16

shared_ptr我的问题涉及make_sharedC++11。我有两个向量,第一个存储智能指针,第二个存储原始指针。第一个向量按我的预期工作,但向量2 只是令人困惑......

代码示例

#include <iostream>
#include <vector>
#include <memory>

int main() {
    std::vector<std::shared_ptr<int>> vector1;
    vector1.push_back(std::make_shared<int>(1));
    vector1.push_back(std::make_shared<int>(2));
    vector1.push_back(std::make_shared<int>(3));

    std::vector<int*> vector2;
    vector2.push_back(std::make_shared<int>(4).get());
    vector2.push_back(std::make_shared<int>(5).get());
    vector2.push_back(std::make_shared<int>(6).get());

    std::cout << "vector1 values:" << std::endl;
    for(auto &value: vector1) { std::cout << *value << std::endl; }

    std::cout << "vector2 values:" << std::endl;
    for(auto &value: vector2) { std::cout << *value << std::endl; }

    return 0;
}


输出

vector1 values:
1
2
3
vector2 values:
6
6
6


问题

我意识到创建原始指针而不是尝试转换智能指针会简单得多,但这让我很想知道为什么会这样?另外为什么每次推送都会改变vector2中的所有值?


链接

以下是我在 stackoverflow 中发现的一些问题,但他们没有回答我的问题,或者我可能不明白答案......

4

2 回答 2

10

您正在看到未定义的行为。当你这样做时:

vector2.push_back(std::make_shared<int>(4).get());

您正在创建一个临时的shared_ptr,并将指向其托管对象的指针复制到您的vector. 这立即变成了一个悬空指针。

于 2014-05-07T21:57:25.440 回答
10

您将使用 a 的原因shared_ptr是您希望在指向它的所有实例超出范围时释放它指向的内存。在shared_ptr你调用.get()它之后立即被销毁,所以你立即有一个悬空指针。取消引用操作的结果是未定义的,这意味着它可能会或可能不会返回一个有意义的值,或者它甚至可能会做一些完全不相关的事情(比如崩溃)。

这是一个特点。您希望这种情况发生:否则,您将泄漏内存。想象一下这段代码:

vector<int> integers;
integers.push_back(*make_shared<int>(6).get());

如果内存没有被释放,那么之后就没有办法释放它,因为你无法恢复 shared_ptr 的托管指针。

于 2014-05-07T21:58:07.507 回答