是否可以通过引用以基类作为参数的函数来传递派生类

Cod*_*der 34 c++ interface

假设我们有一个IBase带有纯虚方法(接口)的抽象基类.

然后,我们得出CFoo,CFoo2从基类.

我们有一个知道如何使用IBase的功能.

Foo(IBase *input);
Run Code Online (Sandbox Code Playgroud)

这些情况下的通常情况是这样的:

IBase *ptr = static_cast<IBase*>(new CFoo("abc"));
Foo(ptr);
delete ptr;
Run Code Online (Sandbox Code Playgroud)

但是指针管理最好避免使用,那么有没有办法在这种情况下使用引用?

CFoo inst("abc");
Foo(inst);
Run Code Online (Sandbox Code Playgroud)

在哪里Foo:

Foo(IBase &input);
Run Code Online (Sandbox Code Playgroud)

gwi*_*rrr 46

是.您不必向上转换对象.必要时,所有对派生类型的引用/指针都会隐式转换为基础对象引用/指针.

所以:

IBase* ptr = new CFoo("abc"); // good
CFoo* ptr2 = static_cast<CFoo*>(ptr); // good
CFoo* ptr3 = ptr; // compile error

CFoo instance("abc");
IBase& ref = instance; // good
CFoo& ref2 = static_cast<CFoo&>(ref); // good
CFoo& ref3 = ref; // compile error
Run Code Online (Sandbox Code Playgroud)

dynamic_cast如果你的类型是多态的,你可能需要考虑使用.

  • @Coder:如果你不知道,问题的原因是因为你传递了'Foo`一个rvalue,并且rvalues不能绑定到非const左值引用(即,如果`Foo`是`Foo(IBase) const&input);`相反,它会编译). (4认同)