参考:http://community.csdn.net/Expert/topic/5355/5355447.xml?temp=.1857721
昨天提了一个问题,得到了许多热心的高手们的帮助,现在终于把这个问题搞清了。在此向回帖的高手们致谢!
按照高手们的提示,我连夜阅读了Inside C++,现在把我在这个问题上的心得写出来,与大家分享。
(1)请参考上面的链接。
(2)可能解决方案之一是:为类的实例构建虚表时,在每个虚表中增加一个地址偏移项,指明相应的基类指针(也是vptr)与当前实例之间的地址偏移量。这一点是可以在编译期间做到的。
(3)Microsoft使用“thunk”,实际上与上面思想是一致的。虚表中的每一项要么指向一个具体虚函数,要么指向一个thunk。thunk是一个小的assembly stub,其中的指令很简单,就是:1、偏移指针 2、以偏移后的指针调用某个具体的虚函数。
所以,在多重继承的情况下,一个派生类的实例中,位于实例顶部的vptr所关联的虚表(如果有的话)是不含thunk的,而所有其它vptr关联的虚表(如果有的话),包含的都是thunk项。
特别感谢:
……
我是一个业余爱好者,希望在这儿结识更多的朋友。
谢谢啦!