Skip to content

Latest commit

 

History

History
5 lines (3 loc) · 777 Bytes

如果拿到虚函数表的储存地址,是否可以改写虚函数表的内容?.md

File metadata and controls

5 lines (3 loc) · 777 Bytes

理论上,如果你能获取到虚函数表的存储地址,你确实可以修改虚函数表的内容,将虚函数的地址替换为其他函数的地址。

然而,这样做通常是非常危险因为它破坏了C++的抽象和类型安全,可能会导致未定义的行为。在大多数操作系统和编译器实现中,虚函数表存放在只读数据段,直接尝试修改虚函数表将会导致程序崩溃。

此外,破坏虚函数表还会引入潜在的安全问题。在某些情况下,恶意软件可能会尝试这样的操作来jc程序的控制流。因此,现代操作系统通常会采取一些保护措施,例如数据执行保护(DEP)和地址空间布局随机化(ASLR)来阻止这种类型的攻击。