关于C++中虚函数表,我们知道这样一些事实:
1. 当class中存在virtual函数时,编译器会为这个class追加一个void** __vfptr数据成员。
2. C++程序运行时,实际函数的调用,是通过查询__vfptr来获取的,从而实现多态。
3. 多态的实现,必须用指针或引用才能实现,拷贝对象或转换对象是无法实现的。
基于以上事实,我理解:
C++中虚函数表存储位置,是class,不是object。
当程序编译时,编译器为每个class分配了虚函数表 vtable(class),存储位置应该是无法修改的常量区域 。
创建对象时,根据对象类型,为对象中void** __vfptr(object)赋值。
对象转换时,根据对象类型,重写对象中void** __vfptr(object)。
指针或引用不涉及对象转换。
反过来,只有void** __vfptr存储在class时,才能符合上面的事实。
以上是2016/7/15面试题引发的思考,也是我的第一篇博客,请大家多多指教。