虚函数的真相(VC编译器如何实现“virtual ”规则)

来源:互联网 发布:免费接单大厅 淘宝 编辑:程序博客网 时间:2024/06/05 15:15

( 1 )virtual 虚函数

 

先看一段简单代码:

Code Segment:

Line01:  #include<stdio.h>

Line02:

Line03:  class Base {

Line04:  public:

Line05:      virtual void __stdcall Output() {

Line06:         printf("Class Base\n");

Line07:     }

Line08:  };

Line09: 

Line10:  class Derive :public Base {

Line11:  public:

Line12:     void __stdcall Output() {

Line13:         printf("Class Derive\n");

Line14:     }

Line15:  };

Line16: 

Line17:  void Test(Base *p) {

Line18:     p->Output();

Line19:  }

Line20: 

Line21:  int __cdecl main(intargc, char* argv[]) {

Line22:     Derive obj;

Line23:     Test(&obj);

Line24:     return 0;

Line25:  }   

 

基类的“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 功能

    







 

原创粉丝点击