分享

栈的初始化

 宁波草堂 2015-10-10
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

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多