1.1、栈是一种具有后进先出性质的数据组织方式,也就是说后存放的先取出,先存放的后取出。栈低是第一个进栈的数据所存放的位置,栈顶是最后一个进栈的数据处的位置。 1.2、满栈、空栈 根据SP指针指向的位置,栈可以分为满栈和空栈。 1、满栈:当堆栈指针SP总是指向最后压人堆栈的数据。 2、空栈:当堆栈指针SP总是指向下一个将要放入数据的空位置。 备注:ARM采用满栈 1.3、升栈、降栈 升栈:随着SP指针移动方向,栈可以分为升栈和降栈。 1、升栈:随着数据的入栈,SP指针从低地址到高地址移动 2、降栈:随着数据的入栈,SP指针从高地址到底地址移动 备注:ARM采用降栈 1.4、栈帧 简单的讲,栈帧就是一个函数所使用的那部分栈,所有函数的栈帧串联起来就组成了一个完整的栈,栈帧的两个边界分别由fp(r11)sp(r13)来限定。 2.1、栈的作用 保存局部变量、传递参数、保存寄存器的值 3.1、代码 init_stack: ldr sp, =0x34000000 mov pc, lr
|
|
来自: 宁波草堂 > 《第1课-栈初始化》