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

来源:互联网 发布:jquery.easing.min.js 编辑:程序博客网 时间:2024/06/06 04:23

内存分配

示例1

int a[5];

示例1
汇编结果:没有分配内存

char a[1024*4048];

示例2

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

这里写图片描述

汇编结果:

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

示例3

int *a = new int[3];

这里写图片描述

汇编结果:

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

示例4

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

这里写图片描述

汇编结果:

  • 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
0 0
原创粉丝点击