auto_ptr设计

Nav*_*K N 1 c++

在我看来,一个类应该提供一个定义明确的抽象,没有私有成员就不应该在没有类知识的情况下进行修改.但是当我检查"auto_ptr"(或任何其他智能指针)时,违反了此规则.请参阅以下代码

class Foo{
public:
   Foo(){}
};

int main(int argc, char* argv[])
{
   std::auto_ptr<Foo> fooPtr(new Foo);
   delete fooPtr.operator ->();
   return 0;
}
Run Code Online (Sandbox Code Playgroud)

运算符重载( - >)给出了底层指针,可以在不知道"auto_ptr"的情况下修改它.我不能认为它是一个糟糕的设计,因为智能指针是由C++极客设计的,但我想知道为什么他们允许这个.有没有办法编写没有这个问题的智能指针.

欣赏你的想法.

j_r*_*ker 5

智能指针应该具有两个理想的属性:

  1. 可以检索原始指针(例如,用于传递给传统库函数)
  2. 无法检索原始指针(以防止双重删除)

显然,这些属性是矛盾的,不能同时实现! 甚至Boost shared_ptr<Foo>等人.有get(),所以他们有这个"问题".在实践中,第一个更重要,所以第二个必须去.

顺便说一下,operator->()当普通的旧get()方法导致同样的问题时,我不确定为什么你达到了稍微模糊的地方:

std::auto_ptr<Foo> fooPtr(new Foo);
delete fooPtr.get();
Run Code Online (Sandbox Code Playgroud)