1

我的班级有一个指针向量:

ptr_vector<Class> vec;

并且在一些“设置”方法中向向量添加了一些类:

void setupOrSomething()
{
    vec.push_back(new Class(...));
    ....
}

现在这个类的客户可能希望将他们的 Class 对象添加到这个类列表中:

void addThingToMyList(Class *cPointer)
{
    vec.push_back(cPointer);
}

他们可能希望通过传递相同的指针来删除它们:

void removeThingFromMyList(Class *cPointer) { ... }

现在,如果我理解正确,在阅读了这个答案(https://stackoverflow.com/a/357043/48998)之后,我需要按如下方式实现该方法:

void removeThingFromMyList(Class *cPointer)
{
    vec.release(std::find_if(vec.begin(),vec.end(),CheckPointerValue(cPointer)).release();
}

struct CheckPointerValue
{
     CheckPointerValue(Class* c):cptr(c) {}
     bool operator()(Class const& X)    { return &X == cptr;}
     private:
        Class* cptr;
};

我知道我还必须在从 ptr_vector.release() 返回的 auto_ptr 上再次调用 release()。

我是否正确假设这将确保此方法的调用者(RemoveThing ...)将保留对其 Class 对象的有效引用并且不会被删除?我只是想让 vec 获得临时所有权,然后放弃它。

4

1 回答 1

1

是的,它们将保留指向有效实例的指针。当然,他们首先需要知道指针指向一个有效的实例,并且指向该实例的指针存储在向量中。如果不是,您将获得未定义的行为,并且可能是段错误。

于 2012-05-21T02:11:53.140 回答