码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2016-05-12 15:15:18      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:

内存分配

示例1

int a[5];

技术分享
汇编结果:没有分配内存

示例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

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

标签:

原文地址:http://blog.csdn.net/quantumenergy/article/details/51365425

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!