c++ 内存分配过程(通过汇编,寄存器和Memory分析)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c++ 内存分配过程(通过汇编,寄存器和Memory分析),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含893字,纯文字阅读大概需要2分钟。
内容图文
![c++ 内存分配过程(通过汇编,寄存器和Memory分析)](/upload/InfoBanner/zyjiaocheng/1150/111fa87aff554a2a913a21b432168ab3.jpg)
内存分配
示例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 = newint[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
原文:http://blog.csdn.net/quantumenergy/article/details/51365425
内容总结
以上是互联网集市为您收集整理的c++ 内存分配过程(通过汇编,寄存器和Memory分析)全部内容,希望文章能够帮你解决c++ 内存分配过程(通过汇编,寄存器和Memory分析)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。