- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言的那些小秘密之堆栈
C 语言的那些小秘密之堆栈
在讲解堆栈之前,我们先要来说说其实我们常说的堆栈是两种数据结构。那么什么是堆
什么又是栈呢?
栈,是硬件。主要作用表现为一种数据结构,是只能在某一端插入和删除的特殊线性表。
它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数
据的时候从栈顶开始弹出数据 (最后一个数据被第一个读出来)。栈是允许在同一端进行插
入和删除操作的特殊线性表。允许进行插入和删除操作的一端称为栈顶(top),另一端为栈
底(bottom);栈底固定,而栈顶浮动;栈中元素个数为零时称为空栈。插入一般称为进栈
(PUSH),删除则称为退栈 (POP)。 栈也称为先进后出表。栈可以用来在函数调用的
时候存储断点,做递归时要用到栈 !
以上定义是在经典计算机科学中的解释。
在计算机系统中,栈则是一个具有以上属性的动态内存区域。程序可以将数据压入栈中,
也可以将数据从栈顶弹出。在 i386 机器中,栈顶由称为 esp 的寄存器进行定位。压栈的操
作使得栈顶的地址减小,弹出的操作使得栈顶的地址增大。
栈在程序的运行中有着举足轻重的作用。最重要的是栈保存了一个函数调用时所需要的
维护信息,这常常称之为堆栈帧或者活动记录。堆栈帧一般包含如下几方面的信息:
1. 函数的返回地址和参数
2. 临时变量:包括函数的非静态局部变量以及编译器自动生成的其他临时变量。
堆,是一种动态存储结构,实际上就是数据段中的自由存储区,它是 C 语言中使用的
一种名称,常常用于动态数据的存储分配。堆中存入一数据,总是以 2 字节的整数倍进行
分配,地址向增加方向变动。堆可以不断进行分配直到没有堆空间为止,也可以随时进行释
放、再分配,不存在次序问题。
堆和栈在使用时相向生长,栈向上生长,即向小地址方向生长,而堆向下增长,即向
大地址方向,其间剩余部分是自由空间。使用过程中要防止增长过度而导致覆盖。
一般的程序我们都是使用小内存模式。
明白了堆和栈的概念之后我们来看一个面试的c 语言题目。代码要相关要求如下所示:
#include iostream
using namespace std;
void print()
{
//这里进行打印 arr 数组,print 不准传参数
}
int main()
{
int s=0;
int ss=0;
char *str=fdsafdsafdsafdsafdsafdsafdsa;
char fdsa=f;
char srt[8];
int arr[]={32,43,3,567,987,21,56};//数值随即
print();
return 0;
}
刚刚一开始看到这个题目时,你可能有点发懵,心想可能在不传递参数的情况下打印 arr 数
组的内容,但是看看我们的标题就应该知道该题跟栈有关系,在做之前我们先来回顾几个知
识点。
push 操作先修改指针,后将信息入栈。
ESP 为堆栈指针,栈顶有 ESP 寄存器来定位。压栈的操作使得栈顶的地址减小,弹出的操
作使得栈顶的地址增大。
EBP 是 32 位的 BP,EBP 是基址指针,EBP 与 BP 的关系就像AX 与 AL 、AH 的关系一样。
BP 为基指针寄存器,用它课直接存取堆栈中的数据,他的作用在调用函数时保存 ESP,使
函数结束时可以正确返回。
c 的默认函数压栈操作为:
参数是从右向左压栈的,默认四字节对齐,函数里面定义的变量是默认对齐方式变量首
地址是自身结构体里边最大标准数据类型字节的整数倍。
我们先来看看上面这段代码的汇编语句:
//*******************************************start*********************************************//
.file push.c
.text
.globl print
.type print, @function
print:
pushl %ebp
movl %esp, %ebp
popl %ebp
ret
.size print, .-print
.section .rodata
.LC0:
.string fdsafdsafdsafdsafdsafdsafdsa
.text
.globl main
.type main, @function
main:
pushl
您可能关注的文档
最近下载
- 分子技术的临床应用题库及答案-2025年华医网继续教育.docx VIP
- 采矿工程毕业设计(论文)-平顶山矿1.2Mta新井设计(全套图纸).doc VIP
- Zebra斑马ZQ630 用户手册.pdf
- 2025年高中语文复习讲义选择性必修下册(一) 单篇梳理2 项脊轩志.docx VIP
- 风电机组叶片防雷相似性对比研究.pptx VIP
- 2026年中国长城资产管理股份有限公司校园招聘笔试模拟试题及答案解析.docx VIP
- 国开2024年秋《经济法学》计分作业1-4答案形考任务.docx
- 2014年q12 impact提升计划管理表(结构).xls VIP
- 党政办公室工作人员业务培训教学演示课件.ppt VIP
- 山梨酸钾MSDS化学物质技术说明书.pdf VIP
原创力文档


文档评论(0)