在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

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...