1.non-virtual函数是在编译时完成解析的,根据该对象被调用时的类型来判断!!切记这点。
2.凡基类定义有一个(或多个)虚函数,应该要将其destructor声明为virtual,但不要把destructor声明为纯虚函数。
3.如果要跳过虚函数机制,使函数在编译时就完成解析,使用class scope运算符可以完成目的。即class::function
4.data member如果是一个reference,必须在constructor的member initialization list中加以初始化
5.子类的copy assignment operator必须显示的调用基类的copy assignment operator
6.子类覆盖基类的某个虚函数而进行声明操作时,不一定得加上关键字virtural。编译器会依据两个函数的原型声明,决定某个函数是否会覆盖其基类的同名函数。
7.“返回类型必须完全吻合”的例外情况是,当某个基类的虚函数返回某个基类形式,子类的同名函数便可以返回该基类所派生出来的类型。
8.虚函数的静态解析:
基类的constructor和destructor
当使用基类的对象,而非基类的reference或point时
9.当为基类声明一个对象时,同时也就分配了足以容纳该实际对象的内存空间,如果稍后传人的却是一个派生类对象,那么就没有足够的内存放置派生类中的各个data member
10.typeid static_cast dynamic_cast