可到 CSDN 下载中心下载全文 http://download.csdn.net/detail/Dreamcode/201005
( 1 )virtual 虚函数
先看一段简单代码:
#include<stdio.h>
class Base {
public:
virtual void __stdcall Output() {
printf("Class Base\n");
}
};
class Derive :public Base {
public:
void __stdcall Output() {
printf("Class Derive\n");
}
};
void Test(Base *p) {
p->Output();
}
int __cdecl main(intargc, char* argv[]) {
Derive obj;
Test(&obj);
return 0;
}
基类的“Output”函数是个虚函数。那么,很明显地,程序的运行结果将是:
( 2) virtual function table 虚函数表
先来分析我们的main函数中的Derive类的对象obj,看看它的内存布局,由于没有数据成员,它的大小为4个字节,只有一个vfptr,所以obj的地址也就是vfptr的地址了。
对一个C++类,如果它要呈现多态(一般的编译器会将这个类以及它的基类中是否存在virtual关键字作为这个类是否要多态),那么类会有一个virtual function table,而每一个实例(对象)都会有一个virtual function pointer(以下简称vfptr)指向该类的virtual function table的起始地址,而virtual function table表格地址所对应的内存单元的内容就是虚函数地址(其实并不是真正的函数地址,而是跳转到函数的jmp指令的地址)。
( 2 ) 实现 virtual 功能