数据结构---栈

本文详细介绍了C语言中内存的五大部分,重点解析了堆和栈的区别,包括管理方式、内存大小、内存分配效率以及生长方向。接着深入探讨了数据结构中的栈,解释了栈的定义、顺序栈和链栈的实现,以及栈的典型应用,如浏览器回退功能和括号匹配问题的检测。
摘要由CSDN通过智能技术生成

(一)栈之基础补充

 C语言内存分配

        对于一个C语言程序而言,内存空间主要由五个部分组成 代码段(text)数据段(data)未初始化数据段(bss)堆(heap)栈(stack) 组成,其中代码段,数据段和BSS段是编译的时候由编译器分配的,而堆和栈是程序运行的时候由系统分配的。布局如下:

,就是那些由编译器在需要的时候分配,在不需要的时候自动清楚的变量的存储区。里面的变量通常是局部变量、函数参数等。

,就是那些由new分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般来说一个new就要对应一个delete。如果程序员没有释放掉,那么在程序结束后,操作系统会自动回收。

自由存储区,就是那些由malloc等分配的内存块,与堆是十分相似的,不过它是用free来结束自己的生命周期。

全局/静态存储区,全局变量和静态变量被分配到同一块内存中,在旧版本的C语言中

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尘 关

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值