news 2026/6/18 20:18:28

虚函数的反汇编

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
虚函数的反汇编

虚函数的反汇编

虚函数机制

当类中有虚函数时,编译器会把类中所有虚函数的地址统一放在一张地址表中,这张表叫做虚函数地址表。同时编译器会在类中添加一个隐藏数据成员,称为虚表指针,该指针保存着虚函数表的首地址,用于记录和查找虚函数。

先来看一个简单的例子:

#include<stdio.h>classPerson{public:virtualintgetAge(){returnage;}virtualvoidsetAge(intage){this->age=age;}private:intage;};intmain(intargc,charconst*argv[]){Person person;return0;}

main函数的反汇编代码如下:

执行完构造函数之后,我们查看rcx中保存的地址所指向的内存地址:

我们反汇编00007ff7`ab3725c7和00007ff7`ab372b4e这两个地址:

可以发现,这就是两个虚函数的首地址,对象的地址就是虚函数表的首地址。

我们来看看默认构造函数里面做了什么:

默认构造函数把虚函数表的首地址赋值给了this指针(rcx),并返回之。

因为虚表信息在编译后会被链接到对应的执行文件中,所以获得的虚表地址是一个相对固定的地址。虚表中虚函数的地址排列顺序因虚函数在类中的声明顺序而定,先声明的虚函数的地址会被排列在虚表靠前的位置。第一个被声明的虚函数的地址在虚表的首地址处。

对于含有构造函数的类而言,其虚表初始化过程和默认构造函数相同,都是在对象首地址处保存虚表的首地址。

在析构函数中,对虚表指针进行的操作和构造函数是一样的。在析构函数中设置虚表指针,与构造函数中这样做,核心目的都是为了确保对象在其生命周期的不同阶段,能够通过正确的虚函数表来调用当前阶段所属类的虚函数,这是C++实现多态机制的基石。

析构是构造的逆过程,顺序是从派生类到基类。首先进入派生类的析构函数,此时对象仍然是一个完整的“派生类对象”,因此需要先执行派生类的析构函数体来清理派生类特有的资源。在派生类的析构函数体执行完毕后,编译器会自动插入代码,将虚表指针还原为基类的虚函数表,然后再调用基类的析构函数。这样,当执行流程进入基类的析构函数时,对象已经被“部分销毁”,其身份退回到了“基类对象”,虚表指针也必须与之匹配。

虚函数的调用

先看代码:

#include<stdio.h>classPerson{public:virtualintgetAge(){returnage;}virtualvoidsetAge(intage){this->age=age;}private:intage;};intmain(intargc,charconst*argv[]){Person person;person.getAge();return0;}

对于通过对象直接调用虚函数,是不需要查找虚函数表的,因为对象的类型在编译期就可以确定了,是静态绑定,没有多态的情况。

只有通过对象指针或者引用调用虚函数的时候,才需要查询虚表进行调用。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 5:02:16

5分钟搞定CAJ转PDF:免费开源工具的完整使用指南

5分钟搞定CAJ转PDF&#xff1a;免费开源工具的完整使用指南 【免费下载链接】caj2pdf 项目地址: https://gitcode.com/gh_mirrors/caj/caj2pdf 还在为CAJ格式的学术文献无法在常用PDF阅读器中打开而烦恼吗&#xff1f;caj2pdf这款开源工具能够完美解决CAJ转PDF的格式兼…

作者头像 李华
网站建设 2026/6/17 16:31:43

Minecraft基岩版跨平台启动器完整指南

Minecraft基岩版跨平台启动器完整指南 【免费下载链接】mcpelauncher-manifest The main repository for the Linux and Mac OS Bedrock edition Minecraft launcher. 项目地址: https://gitcode.com/gh_mirrors/mc/mcpelauncher-manifest 还在为无法在Linux和macOS系统…

作者头像 李华
网站建设 2026/6/17 13:17:30

Windows 11性能优化实战:3招让你的系统重获新生

Windows 11性能优化实战&#xff1a;3招让你的系统重获新生 【免费下载链接】Win11Debloat 一个简单的PowerShell脚本&#xff0c;用于从Windows中移除预装的无用软件&#xff0c;禁用遥测&#xff0c;从Windows搜索中移除Bing&#xff0c;以及执行各种其他更改以简化和改善你的…

作者头像 李华
网站建设 2026/6/16 1:51:51

caj2pdf免费转换工具:彻底解决CAJ格式兼容问题的终极方案

caj2pdf免费转换工具&#xff1a;彻底解决CAJ格式兼容问题的终极方案 【免费下载链接】caj2pdf 项目地址: https://gitcode.com/gh_mirrors/caj/caj2pdf 您是否曾经为了阅读知网下载的CAJ格式文献而苦恼&#xff1f;想象一下&#xff0c;在移动设备上无法直接打开&…

作者头像 李华
网站建设 2026/6/15 23:46:16

Z-Image-Turbo云海表现力测试:复杂自然场景生成案例

Z-Image-Turbo云海表现力测试&#xff1a;复杂自然场景生成案例 1. 引言&#xff1a;当AI遇见壮丽山河 你有没有想过&#xff0c;只需几句话&#xff0c;就能让AI为你“画”出一幅云海翻腾、日出金光洒满山巅的绝美风景&#xff1f;这不是电影特效&#xff0c;也不是专业画家…

作者头像 李华
网站建设 2026/6/16 1:47:25

MGeo模型热更新机制:不停机替换新版本地址匹配模型

MGeo模型热更新机制&#xff1a;不停机替换新版本地址匹配模型 在处理中文地址数据时&#xff0c;实体对齐是一项极具挑战性的任务。不同系统中记录的地址信息往往存在表述差异、缩写习惯、顺序颠倒等问题&#xff0c;例如“北京市朝阳区建国门外大街1号”和“北京朝阳建国外大…

作者头像 李华