Chinaunix

标题: gdb 虚函数表 [打印本页]

作者: hongyunqi    时间: 2010-07-24 10:20
标题: gdb 虚函数表
本帖最后由 hongyunqi 于 2010-07-24 10:23 编辑

工作中遇到的问题,希望有人能帮忙解答

三个类的定义抽象出来是这样的
  1. class B1
  2. {
  3. public:
  4. virtual void func1();
  5. }
  6. class B2
  7. {
  8. public:
  9. virtual void func2();
  10. }

  11. class D: public B1, public B2
  12. {
  13. public:
  14. void func1();
  15. void func2();
  16. }

  17. int main()
  18. {
  19.     B2 *dd = new D();
  20.     dd->func2();
  21. }
复制代码
类D多重继承自两个类B1和B2,那么D的对象正常情况下应该有两个虚函数表。这在程序正常运行的时候,gdb进去也的确能看到两个虚函数表。在执行dd->func2()时, 传进来的就是B2的虚函数表地址,在加上偏移就能找到func2()了。

但是某种异常情况,D的对象居然只有一个虚函数表,B1和B2 的虚函数全部都挤在一个表里。并且B1的虚函数排在前面,B2的虚函数排在后面。这样在执行dd->func2()的时候,传进来的就是这个唯一的虚函数表,加上偏移就会找到错误的func1()了(因为B1的虚函数排在前面)。无效的调用func1()就会导致系统coredump。

以上关于虚函数表的部分是自己gdb进去后分析的,也有可能不对。但是现象就是本应该调用func2,却调到func1了。

大家想想怎么会有这种情况啊?
作者: hongyunqi    时间: 2010-07-24 20:05
哎 自己顶




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2