c++ 内存分配过程(通过汇编,寄存器和Memory分析)

内存分配

示例1

int a[5];

c++ 内存分配过程(通过汇编,寄存器和Memory分析)_第1张图片
汇编结果:没有分配内存

示例2

int a[5] = {1,2,3,4,5}

c++ 内存分配过程(通过汇编,寄存器和Memory分析)_第2张图片

汇编结果:

  • movl $0x1c,0x1f(%esp) : 把立即数1存放在esp寄存器中指向地址+0x1c的地址( 0x6afefc)中
  • 后面的代码分别存储2,3,4, 5 到依次偏移4个字节的地址中(int 占 4个字节)
  • 在memory中查看6afefc地址中的数据

示例3

int *a = new int[3];

c++ 内存分配过程(通过汇编,寄存器和Memory分析)_第3张图片

汇编结果:

  • movl $0xc,(%esp) 把立即数12存放在寄存器esp指向的地址中
    表明需要12个字节的存储空间、

示例4

 int *a = new int[3];
 *a = 1;
 *(a+1) = 2;
 *(a +2) = 3;

c++ 内存分配过程(通过汇编,寄存器和Memory分析)_第4张图片

汇编结果:

  • movl $0xc,(%esp) 同上
  • mov %eax,0x1c(%esp) 把寄存器eax的值存储在0x1c(%esp)这个地址中
  • mov 0x1c(%esp),%eax 恢复寄存器eax的值
  • movl $0x1,(%eax) 把立即数1存到eax寄存器指向的地址中

后续步骤依次是:

  • 恢复寄存器eax的值
  • 在寄存器eax指向地址向后移动4个字节的地址中存储存储立即数2
  • 由于add把结果保存在eax中,此时eax是722ac4,知道初值应该是:722ac0 (其实就是0x1c(%esp) 中存储的值)
  • 在memory中查看722aco,发现依次存放1 和 2

你可能感兴趣的:(C++,汇编,内存分配)