栈 , 堆 , 静态存储区
来源:互联网 发布:全球汽车行业数据库 编辑:程序博客网 时间:2024/05/16 15:40
程序中的 栈
栈是现代计算机程序里最为重要的概念之一。
栈在程序中用于维护函数调用上下文,没有栈就没有函数,没有局部变量。main函数也会用到栈。
不可以返回一个指向局部变量的指针,因为函数返回后,局部变量被释放。但是可以返回局部变量的值。
栈保存了一个函数调用所需的维护信息:
- 函数参数,函数返回地址
- 局部变量
- 函数调用上下文
程序中的 堆
为什么有了栈还需要堆?
栈上的数据在函数返回后就会被释放掉,无法传递到函数外部,如:局部数组。
堆是程序中预留的一块巨大的内存空间,可由程序自由使用。
堆中被程序申请使用的内存在程序主动释放前将一直有效。
堆空间通过申请才能获得!
malloc函数申请的空间就是堆中的空间。
系统对堆空间的管理方式:
空闲链表法,位图法,对象池法等等
简介一下空闲链表法:
链表中每个元素都是一个指向一定大小空间的指针。
当申请一个4字节的空间时,编译器会在链表中找一个最接近4字节的空间的指针,如5字节。然后把12字节后面的指针指向50字节处,也就是把5字节的单元踢出去。函数就返回指向5字节空间的那个指针。因此malloc分配的空间都会稍大一点。free释放空间后,就在链表中再插入一个单元。只使用不归还就会导致节点用完,表头指向NULL,这时malloc就返回NULL。
程序中的静态存储区
程序静态存储区随着程序的运行而分配空间,直到程序运行结束时被释放。
在程序的编译期静态存储区的大小就已经确定。
程序的静态存储区主要用于保存程序中的全局变量和静态变量,因此全局变量和静态变量的总和就是静态存储区的大小。
与栈和堆不同,静态存储区的信息最终会保存到可执行程序中。
小结
栈,堆和静态存储区是C语言程序常涉及的三个基本内存区,分工明确:
栈区主要用于函数调用的使用
堆区主要是用于内存的动态申请和归还
静态存储区用于保存全局变量和静态变量
- 静态存储区、堆、栈
- 栈 , 堆 , 静态存储区
- 栈,堆,静态存储区
- 静态存储区、代码区、堆、栈
- C++:静态存储区,堆,栈区别
- 堆、栈和静态存储区
- C++堆,栈,静态存储区介绍
- 堆,栈,静态存储区的理解
- 程序中的栈、堆、静态存储区
- 常量 栈 自由存储区 堆 全局/静态存储区
- 静态存储区、动态存储区、堆、栈理解
- 堆,栈,静态存储区和常量存储区
- 堆,栈,静态存储区和常量存储区
- 堆栈、堆、静态存储区
- 静态存储区、堆区和栈区
- (转)堆、栈、静态存储区、文字常量区
- 简单理解 栈、堆、静态存储区(方法区)
- 内存分配——静态存储区 栈 堆
- .Net基础体系和跨框架开发普及
- 框架 day89 涛涛商城项目(补)-activeMQ应用,及springMVC全局异常处理
- 我的第一个项目---手机安全卫士 DAY ONE
- 九度 题目1483:求最大最小数
- Redis安装、后台启动、卸载
- 栈 , 堆 , 静态存储区
- 接口和抽象类的继承和实现
- 集搜客网络爬虫推荐
- 学习笔记之Serializable
- 写clone()方法时,通常有一行什么代码?
- .Net程序员学用Oracle系列(12):增删改查
- scala闭包与柯里化
- List和Map的区别
- bzoj 1168 [Baltic2008]Gloves