循环时保持对unique_ptr的引用

时间:2014-12-26 06:06:43

标签: c++ c++11 gcc

我想在使用循环时保持对unique_ptr的引用,这样在我离开循环后我仍然保持引用。我知道我无法创建unique_ptr的新副本(显然),所以我想做的是:

const unique_ptr<Object>& ref;
for(auto& s : stuff) {
    if(condition) {
         ref = std::move(s);
    }
}

我意识到这将永远不会起作用,因为ref必须在声明时初始化,如果它是一个const,但在同一个动作中,我不能保持对unique_ptr的引用,除非它是一个const unique_ptr&amp;如果我没有记错,请输入。 我最终做的是:

Object* ref = nullptr;
for(auto& s : stuff) {
    if(condition) {
         ref = s.get();
    }
}

这是一个正确的解决方案还是我应该考虑使用shared_ptr来完成这项工作?

3 个答案:

答案 0 :(得分:6)

救援的功能风格!

const auto &ref = *std::find_if(stuff.begin(), stuff.end(), [=](const std::unique_ptr<Object> &p) {
    return <condition>;
});

或者,移动作业:

std::unique_ptr<Object> ref;
for (auto &&s : stuff) {
    if (condition) {
        ref = std::move(s);
        break;
    }
}

答案 1 :(得分:6)

你不应该这样做!你甚至不应该使用循环[明确]!相反,只需找到位置并从那里开始:

auto it = std::find_if(stuff.begin, stuff.end(),
     [](std::unique_ptr<Object> const& s){ return condition(s); });
if (it != stuff.end()) {
    // get your unique_ptr as appropriate from *it
}
else {
    // deal with the fact that nothing was found
}

答案 2 :(得分:0)

我知道这可能看似违反直觉,但鉴于您的对象已由std::unique_ptr管理,因此其销毁 保证,我使用原始指针没有任何问题:

Object* o = nullptr;

for(auto& s : stuff) {
    if(condition) {
         o = s.get();
    }
}

if(o) {
    // use o->stuff() here
}