boost :: shared_ptr标准容器

时间:2008-09-26 14:57:42

标签: c++ smart-pointers std stdmap

假设我有一个类foo,并希望使用std :: map存储一些boost :: shared_ptrs,例如:

class foo;

typedef boost::shared_ptr<foo> foo_sp;
typeded std::map<int, foo_sp> foo_sp_map;

foo_sp_map m;

如果我向地图添加新的foo_sp但已使用的密钥已存在,是否会删除现有条目?例如:

foo_sp_map m;

void func1()
{
    foo_sp p(new foo);
    m[0] = p;
}

void func2()
{
    foo_sp p2(new foo);
    m[0] = p2;
}

当原始指针(p)被p2替换时,它是否会被释放?我很确定会这样,但我认为值得询问/分享。

3 个答案:

答案 0 :(得分:7)

首先,你的问题标题是boost :: auto_ptr,但实际上你的意思是boost :: shared_ptr

是的,原始指针将被释放(如果没有进一步的共享引用)。

答案 1 :(得分:1)

这取决于你...章节中发生的事情

您的容器类包含foo_sp实例的副本,当您执行m[0] = p2;时,最初位于该位置的p副本超出范围。那时它将被删除如果没有其他foo_sp引用它

如果在第二行foo_sp p(new foo);中声明的副本仍然存在,那么内存将不会被释放。删除所有对它的引用后,该条目将被删除。

答案 2 :(得分:0)

由于stackoverflow不允许我发表评论,我只想回答。 :/

我没有看到“p”超出范围,因此它指向的对象将被释放。 “p”仍将指向它。