微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在C中堆栈到堆栈?

我一直在想,在RISC或ARM等处理器的汇编程序中,C堆栈和堆栈之间的区别是什么?

Proffesor说,要小心,堆栈与你所了解的其他主题(算法和结构,我们在哪里可以了解C)不同,

据我所知,两者都只是保存在内存中的数据,两者都在LastInFirstOut方案上运行,两者都需要在使用后被清理.

我的意思是说,他们不一样,因为他们在两个不同的“世界”,但我错过了一些不同的重要的东西?也许这是它,但它一直在欺骗我.

谢谢

解决方法

堆栈是完全一样的.可以编写一个程序混合的程序集C,它们使用相同的堆栈.

C编译器使用一些关于如何使用堆栈的约定:每个功能项填充一个格式良好的堆栈帧;并在功能离开时进行清理.有一些特定于改变堆栈管理的编译器指令.例如:gcc stack checking

网站上的一些参考资料:google : c stack frame

在组装中,堆栈必须由程序员完全管理.有一个很好的做法是有关如何管理堆栈的规则(例如模拟C规则)

堆栈管理指令也取决于处理器(在x86上的push和pop,ARM上的stmia / ldmfd等),同样的,一些处理器有专用的堆栈指针寄存器(特别是x86),其他的只是常规的(r13在ARM7上.)

了解堆栈管理的一个方法是使用调试器,并进行一些回溯以查看帧内容.

为了很好地了解汇编级别的x86堆栈,我建议您使用this Wikipedia articlethis one for stack frames

原文地址:https://www.jb51.cc/c/112036.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐