我没有 C++ 方面的经验,我来自 Java 背景。最近,我在一次采访中被问到为什么 Java 不允许多重继承,答案很简单。但是,我仍然对 C++ 如何处理这个问题感到好奇,因为它允许您从多个类继承。
具体来说,假设有一个名为 MechanicalEngineer
的类和另一个名为 ElectricalEngineer
的类。两者都有一个名为 buildRobot()
的方法。
如果我们创建第三个类 RoboticsEngineer
会发生什么,它继承自两者并且不覆盖该方法,而您只需调用:
(some instance of RoboticsEngineer).buildRobot()
会抛出异常,还是会使用来自父类(super class)之一的方法?如果是,编译器如何知道使用哪个类?
最佳答案
编译器会将这种情况(即尝试调用 (RoboticsEngineer 的某个实例).buildRobot()
)标记为错误。
发生这种情况是因为派生对象在其自身内部拥有两个基础对象(MechanicalEngineer
实例和 ElectricalEngineer
实例)的拷贝,而单独的方法签名不是足以判断使用哪一个。
如果您在 RoboticsEngineer
中重写 buildRobot
,您将能够通过为类名添加前缀来明确说明要使用哪个继承方法,例如:
void RoboticsEngineer::buildRobot() {
ElectricalEngineer::buildRobot()
}
同样,您实际上可以“强制”编译器使用一个或另一个版本的 buildRobot
,方法是在其前面加上类名:
(some instance of RoboticsEngineer).ElectricalEngineer::buildRobot();
在这种情况下,将调用该方法的 ElectricalEngineer
实现,没有歧义。
当您对 MechanicalEngineer
和 ElectricalEngineer
都有一个 Engineer
基类并且您将继承指定为 时,会给出一种特殊情况>virtual
在这两种情况下。当使用 virtual
时,派生对象不包含 Engineer
的两个实例,但编译器会确保其中只有一个。这看起来像这样:
class Engineer {
void buildRobot();
};
class MechanicalEngineer: public virtual Engineer {
};
class ElectricalEngineer: public virtual Engineer {
};
在这种情况下,
(some instance of RoboticsEngineer).buildRobot();
将毫不含糊地解决。如果 buildRobot 被声明为 virtual
并在两个派生类之一中被覆盖,情况也是如此。无论如何,如果两个派生类(ElectricalEngineer 和 MechanicalEngineer)都覆盖了 buildRobot
,那么就会再次出现歧义,编译器将标记尝试调用 (RoboticsEngineer 的某些实例).buildRobot();
作为错误。
关于c++ - 多个父类(super class)中的多重继承、C++ 和相同方法签名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6765145/