为什么以下代码不允许调用foo(ptr)?
#include <boost/scoped_ptr.hpp>
struct A {
virtual ~A() {}
};
struct B: public A {};
void foo(boost::scoped_ptr<A>& a) {}
void goo(A& a) {}
int main() {
boost::scoped_ptr<B> ptr(new B);
foo(ptr);
B b;
goo(b);
}
我们传递引用的相应表单按预期工作。我们应该不做多态 使用boost scoped_ptr?
g ++ with boost 1.49给了我:
error: invalid initialization of reference of type ‘boost::scoped_ptr<A>&’ from expression of type ‘boost::scoped_ptr<B>’
答案 0 :(得分:5)
这是因为foo
由于某种原因,通过引用获取了作用域指针。这完全没必要,也就是呼叫失败的原因。存在从scoped_ptr<B>
到scoped_ptr<A>
的转换,但不是从scoped_ptr<B>&
到scoped_ptr<A>&
的转换。
你应该将它作为对const的引用传递。
void foo(boost::scoped_ptr<A> const & a) {}
顺便说一句,这不是智能指针本身的“问题”。以下代码失败的原因与您的相同。
void foo(A*& p) {}
int main()
{
B* p = new B;
foo(p); //FAIL
}
为了解决这个问题,您必须通过值传递指针,或者,如果您已经充分变态,则通过引用const
void foo (A * const & p); // <-- a perv wrote this