C++反汇编(一)

时间:2023-03-08 17:22:42

对象/结构体

对象的大小只包括数据成员,成员函数属于执行代码。

对象长度 = sizeof(数据成员1) + sizeof(数据成员2) + ...... + sizeof(数据成员n)

特殊情况公式不正确:

  • 空类:没有任何数据成员
  • 内存对齐
  • 静态数据成员:存放的位置与全局变量一致,所有对象共享这块空间。

当前数据成员类型(最小)长度为M,对齐值为N,实际对齐值q = Min(M,N),其成员的地址安排在q的倍数上。

例子:struct node{

short a;

int b;

};            M = (short) 2 ,N = (默认)8  ,q = 2。

数组

特征: 一组连续的大小相同的空间

若下标是变量,先取出下标再寻址

指针:

特征:固定大小,常见 lea指令,先去地址再寻址。

注:二维字符数组和字符指针数组代码极相似,但寻址内容不相同。前者寻到的是内容,后者寻到的是字符串首地址。