news 2026/4/16 5:29:33

虚函数的反汇编

作者头像

张小明

前端开发工程师

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/4/16 13:03:26

BongoCat输入可视化工具:提升工作效率的数字伴侣

BongoCat输入可视化工具&#xff1a;提升工作效率的数字伴侣 【免费下载链接】BongoCat 让呆萌可爱的 Bongo Cat 陪伴你的键盘敲击与鼠标操作&#xff0c;每一次输入都充满趣味与活力&#xff01; 项目地址: https://gitcode.com/gh_mirrors/bong/BongoCat 在长时间面对…

作者头像 李华
网站建设 2026/4/16 10:54:18

VantUI:一站式跨平台移动端开发解决方案

VantUI&#xff1a;一站式跨平台移动端开发解决方案 【免费下载链接】vantui 基于vant-weapp实现的Taro-React版及H5-React版组件库https://antmjs.github.io/vantui/#/home 项目地址: https://gitcode.com/gh_mirrors/va/vantui 在当今移动互联网飞速发展的时代&#x…

作者头像 李华
网站建设 2026/4/16 6:01:35

完整指南:快速解锁Insyde BIOS隐藏功能

完整指南&#xff1a;快速解锁Insyde BIOS隐藏功能 【免费下载链接】LEGION_Y7000Series_Insyde_Advanced_Settings_Tools 支持一键修改 Insyde BIOS 隐藏选项的小工具&#xff0c;例如关闭CFG LOCK、修改DVMT等等 项目地址: https://gitcode.com/gh_mirrors/le/LEGION_Y7000…

作者头像 李华
网站建设 2026/4/16 5:59:53

OpCore Simplify:让黑苹果安装变得前所未有的简单

OpCore Simplify&#xff1a;让黑苹果安装变得前所未有的简单 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为复杂的OpenCore配置而头疼吗&…

作者头像 李华
网站建设 2026/4/16 5:59:52

不用再查了!Linux开机启动脚本最全避坑指南

不用再查了&#xff01;Linux开机启动脚本最全避坑指南 1. 开机自启不是“写完就能跑”&#xff0c;这些坑你踩过几个&#xff1f; 你是不是也经历过&#xff1a;辛辛苦苦写好一个脚本&#xff0c;配置了开机自启&#xff0c;信心满满地重启系统&#xff0c;结果啥也没发生&a…

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

Fun-ASR系统设置全解析,选对设备事半功倍

Fun-ASR系统设置全解析&#xff0c;选对设备事半功倍 在语音识别技术日益融入办公、教育和客服场景的今天&#xff0c;越来越多用户选择本地化部署的 ASR&#xff08;自动语音识别&#xff09;系统来保障数据安全与处理效率。Fun-ASR 作为钉钉联合通义实验室推出的高性能语音识…

作者头像 李华