c++中的虚函数

c++中的虚函数

该函数对应的反汇编代码

c++中的虚函数

我们可以观察出调用函数的不同,show1函数在编译阶段要调用的函数地址已经确定好,而show2函数是通过寄存器里面的内容来确定,也就是对应call的硬编码不同,静态绑定(即编译阶段就确定)为E8,动态绑定(运行阶段确定要调用函数的地址)为FF,现在我们打印该类的大小

c++中的虚函数

为什么会是4个字节呢?类里面没有成员为什么不是一个字节呢(占位).

于是我们可以猜测,既然是4个字节的大小,会不会是指针呢?

我们在去分析一下函数调用过程中,edx中的值到底是什么。

Mov eax,dword ptr[p]//将指针的内容移动到eax(this指针 类的首地址)

Mov edx,dword ptr [eax](将首地址中的值移动到edx)

Mov eax,dword ptr[edx]edx中的值复制到eax

Call eax调用该处的函数

从这段分析中可以看出,确实为指针,那么他究竟指向哪里。


c++中的虚函数


好了,我们来验证是否正确

c++中的虚函数

程序运行结果

c++中的虚函数