c++ 下的多重继承虚函数调用问题
2016-04-17 21:10
363 查看
最近看老师上课讲的一个关于com组件的程序,当时虽然程序有些复杂,但是感觉自己已经明白原理了。回来自己对着程序一步步演练时,发现结果不对,后来通过断点调试、发现了一个让我惊呆了的问题。下面我把这个问题简化一下。
#include<iostream>
using namespace std;
class A
{
public:
virtual void put()
{
cout << "A" << endl;
}
};
class B
{
public:
virtual void out()
{
cout << "B" << endl;
}
};
class C :public A, public B
{
public:
void put()
{
cout << "C from A" << endl;
}
void out()
{
cout << "C from B" << endl;
}
};
int main()
{
C *c = new C();
B *b = c;
A *a =(A *)b;//将b强制赋值给a
cout << c << endl;
cout << b << endl;
cout << a << endl;
b->out();
a->put();
return 0;
}
发现执行的虽然是put函数,但是运行的却是out函数。
在将B指针强制赋值给A时,A指针的指针值为0017B36C,而且编译器在编译时检查到a的静态类型A有put()函数,所以通过了。但是在实际执行时,通过virtual table执行了put在A中的virtual table的地址,恰好和out在B的virtual table的下标一样,所以执行了out函数。
#include<iostream>
using namespace std;
class A
{
public:
virtual void put()
{
cout << "A" << endl;
}
};
class B
{
public:
virtual void out()
{
cout << "B" << endl;
}
};
class C :public A, public B
{
public:
void put()
{
cout << "C from A" << endl;
}
void out()
{
cout << "C from B" << endl;
}
};
int main()
{
C *c = new C();
B *b = c;
A *a =(A *)b;//将b强制赋值给a
cout << c << endl;
cout << b << endl;
cout << a << endl;
b->out();
a->put();
return 0;
}
发现执行的虽然是put函数,但是运行的却是out函数。
在将B指针强制赋值给A时,A指针的指针值为0017B36C,而且编译器在编译时检查到a的静态类型A有put()函数,所以通过了。但是在实际执行时,通过virtual table执行了put在A中的virtual table的地址,恰好和out在B的virtual table的下标一样,所以执行了out函数。
相关文章推荐
- C语言-大整数四则运算
- C++: std::string 与 Unicode 如何结合?
- SM2算法第一篇:ECC加密算法
- C++动态规划
- 棋盘覆盖问题
- C++类型转换运算符之const_cast<newtype>(expression)
- C语言隐式数据类型转换
- VPTR和VTABLE和构造函数与继承
- c/c++中求取字符串,数组,一块内存的长度
- 关于循环重复数字的相加 C语言越来越好玩
- C++中的哑类
- 初探C++类模版学习笔记
- thrift C++做server, C++,python, java做Client例子
- 巩固C语言(八)----进程和线程的区别和练习 & 线程编程
- 学习OpenCV——Kmean(C++)
- 大型分布式C++框架《四:netio之请求包中转站 上》
- sizeof陷阱
- 程序编译链接运行深入剖析
- MFC发送邮件C语言版
- C++编译过程与内存空间