重载解析的使用不会跨越不同类的作用域,所以基类和派生类的同名函数不能通过参数类型完成解析。可以使用using指令在派生类中申明基类的同名函数,这样就可以进行参数类型的解析。如:
class A{
public:
int f(int);
};
class B: public A{
public:
using A::f;//可以在派生类中完成函数类型解析。
char f(char);
};
在任何派生类中的virtual基类(virtual继承)总用铜一个共享对象表示。在一个继承图中,通过virtual继承的基类,总是用这个类的同一个对象表示(类似静态),未通过virtual继承的每个基类都有自己的子对象表示。多继承是需要防止对一个基类的重复继承,引起两个重复基类对象的出现。
使用dynamic_cast时,如果操作的是引用,dynamic_cast本身会进行可转换的检查,如果对引用的dynamic_cast的操作对象不具有所需要的类型,会抛出bad_cast异常。
dynamic_cast不能从void*出发进行强制,此时必须使用static_cast,dynamic_cast会进行运行时类型检查,static_cast不检查被强制的对象。
typeid运算符是为了知道一个类的名字或者它的布局而出现的,它取得一个对象,该对象代表着对应运算对象的类型。