在C中堆栈到堆栈?

前端之家收集整理的这篇文章主要介绍了在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&C++相关文章