如何在C 汇编代码中找到VPTR

How to find VPTR in C++ assembly code?

本文关键字:VPTR 代码 汇编      更新时间:2023-10-16
class Base {
 public:
  Base() {}
  virtual void Get() { }
};
class Derivered : public Base {
 public:
  virtual void Get() { }
};
int main() {
  Base* base = new Derivered();
  base->Get();
  return 0;
}

我使用GCC 5.4.0来编译代码,然后使用objdump -S a.out拆卸二进制文件。我想找到基本的VPTR,但仅显示一个未知地址0x80487d4。最大地址号是0x80487b7,我听不懂。命令列表:g++ test.cpp -O0; objdump -S a.out

080486fe <_ZN4BaseC1Ev>:
 80486fe:   55                      push   %ebp
 80486ff:   89 e5                   mov    %esp,%ebp
 8048701:   ba d4 87 04 08          mov    $0x80487d4,%edx
 8048706:   8b 45 08                mov    0x8(%ebp),%eax
 8048709:   89 10                   mov    %edx,(%eax)
080486fe <_ZN4BaseC1Ev>:
  80486fe:   55                      push   %ebp
  80486ff:   89 e5                   mov    %esp,%ebp
  8048701:   ba d4 87 04 08          mov    $0x80487d4,%edx
  8048706:   8b 45 08                mov    0x8(%ebp),%eax
  8048709:   89 10                   mov    %edx,(%eax)

是...

push %ebp             ;- save frame pointer
mov %esp, %ebp        ;- mov esp-> ebp -ebp is frame pointer
mov $0x80487d4, %edx  ; load vptr address into edx
mov 0x8(%ebp), %eax   ; ld eax with address of this
mov %edx,(%eax)       ; store vptr in this byte 0