0

我很惊讶编译器拒绝编译这种代码:

class A { virtual ~A() {} };
class B : public A { virtual ~B() {} void foo() {} };
//...
boost::scoped_ptr<A> p1(new B);
boost::scoped_ptr<B> p2 = boost::dynamic_pointer_cast<B>(p1);
p2->foo();

为什么这是不可能的?最好的方法是什么?

我找到了这个解决方案:

boost::scoped_ptr<A> p1(new B);
B* p2 = dynamic_cast<B*>(p1.get());
p2->foo();

有没有办法只使用智能指针?

注意:出于兼容性原因,我不使用 C++11。

4

1 回答 1

1

p1拥有该B对象,并将在其析构函数中将其删除。如果您允许创建第二个智能指针 ( p2),该指针也将删除其析构函数中的对象,您将遇到问题。

就个人而言,我会使用对引用而不是指针的强制转换,但除此之外,您找到了唯一的解决方案。

于 2017-02-23T07:55:01.030 回答