c++虚函数反汇编特征
2021/7/18 17:06:16
本文主要是介绍c++虚函数反汇编特征,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
class MyClass { public: virtual int getNumber() { return m; } virtual void setnumber(int number) { m = number; } private: int m; };
这里实例化类大小占8个字节 int*4+32位的指针 虚表
在初始化默认构造函数时 会把虚函数指针放到虚表中 通过虚表来调用函数 虚函数多态性 都是和继承有关
#include <iostream> using namespace std; class A { public: virtual void foo() { cout << "A::foo() is called" << endl; } }; class B :public A { public: void foo() { cout << "B::foo() is called" << endl; } }; int main(void) { A* a = new B(); a->foo(); return 0; }
在调用父类后 会去从虚表中直接调用 b的foo地址
在pop ecx 拿到this指针地址 再去赋值
通过对寄存器的值判断 可以肯定 this指针里存储的时 虚表地址可以动过 ida 找到所有函数引用 就能找到所有有关函数 也可以通过反推找到构造函数
其实本质上来说就是 类对象成员有一个 虚函数指针类型 可以通过 this指针解引用 找到虚表
这篇关于c++虚函数反汇编特征的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-20获取apk的md5值有哪些方法?-icode9专业技术文章分享
- 2024-11-20xml报文没有传 IdentCode ,为什么正常解析没报错呢?-icode9专业技术文章分享
- 2024-11-20如何知道代码有没有进行 Schema 验证?-icode9专业技术文章分享
- 2024-11-20Mycat教程:新手快速入门指南
- 2024-11-20WebSocket入门:轻松掌握WebSocket基础
- 2024-11-19WebSocket入门指南:轻松搭建实时通信应用
- 2024-11-19Nacos安装资料详解:新手入门教程
- 2024-11-19Nacos安装资料:新手入门教程
- 2024-11-19升级 Gerrit 时有哪些注意事项?-icode9专业技术文章分享
- 2024-11-19pnpm是什么?-icode9专业技术文章分享