内存中的堆和栈
来源:互联网 发布:淘宝订单存在异常 编辑:程序博客网 时间:2024/05/17 08:54
内存结构:
堆区,栈区,全局区,文字常量区,程序代码区
栈:
栈是你的电脑内存的一个特别区域,它用来存储被每一个function(包括mian()方法)创建的临时变量。栈是FILO,就是先进后出原则的结构体,它密切的被CPU管理和充分利用。每次function声明一个新的变量,它就会被“推”到栈中。然后每次一个function退出时,所有关于这个函数中定义的变量都会被释放(换句话说就是删除)。一旦栈中的变量释放,这块区域就会变成可用的,提供给其他栈中的变量。
用栈存储变量的好处:
内存是被你管理的。你不用手动的创建内存,不用当你不在需要它的时候手动释放内存。另外,由于CPU组织栈内存很高效。读出和写入栈变量是很快的。
栈的概念:
当一个function退出时,所有它的变量都会从栈中弹出,以后都会永远消失。因此栈中的变量本质是局部的。这和我们原来理解为变量作用域或者本地或者全局变量是相关的。在C中,一个公共的bug 是从你程序中的一个function外尝试访问一个在栈中的这个function的变量(在该function已经退出后)。
关于栈的另一个特点我们应该记住,就是存储在栈中的变量的大小有限制。而堆上创建变量不用考虑。
总结栈:
a、栈的伸长和伸缩就是函数压入或者推出局部变量。
b、我们不用自己去管理内存,变量创建和释放都是自动的。
c、栈中的变量只有在函数创建运行时存在。
堆:
堆也是我们的计算机内存中的一个区域,但是他不是自动管理的。而且也不是被CPU密切的管理着。它是一片更加自由的内存区域(很大)。要想在堆上创建内存,我们必须使用malloc()或者calloc(),他们都是C语言编译的。一旦你在堆上分配内存,当你不在需要的时候你必须用free()去销毁。如果你不销毁或者销毁失败,你的程序就会有内存泄露。换句话说就是堆内存会一直在,其他进程无法使用。
堆没有变量大小的限制(除了你电脑的物理限制条件外)。堆内存读出和写入都比较慢,因为它必须使用指针图访问堆内存。
栈和堆的优缺点:
栈:
1)、快速访问。
2)、没有必要明确的创建分类变量,因为它是自动管理的。
3)、空间被CPU高效地管理着,内存不会变成碎片。
4)、只有局部变量
5)、受限于栈大小(取决于操作系统)
6)、变量不能调整大小。
堆:
1)、变量可以被全局访问
2)、没有内存大小限制
3)、(相对)访问比较慢
4)、没有高效地使用空间,随着块内存的创建和销毁,内存可能会变成碎片。
5)、你必须管理内存(变量的创建和销毁你必须要负责)
6)、变量大小可以用realloc( )调整- 内存中的堆和栈
- 内存中的堆和栈
- 内存中的堆和栈
- 内存中的堆和栈
- 内存中的堆和栈
- Java中的栈内存和堆内存
- JAVA中的栈内存和堆内存
- java中的栈内存和堆内存
- Java中的堆内存和栈内存
- java中的栈内存和堆内存
- Java中的栈内存和堆内存
- java中的栈内存和堆内存
- Java中的堆内存和栈内存
- JAVA中的堆内存和栈内存
- zz内存中的堆和栈
- 关于 内存中的 堆和栈
- java中的内存分配 堆和栈
- 内存分配中的堆和栈
- 有关标准变量和环境变量的技巧
- 面向对象,构造以及static应用整理
- 基础篇 4. 深入JSP技术
- 发包sdk 根据debug和release版本切换请求不同的url环境
- 数据中心网络拥塞控制分析之DC-Vegas
- 内存中的堆和栈
- VSCode 快捷键
- 编辑距离问题
- c语言题目练习(2)
- hdu 1171 (多重背包模板)
- Fresco 动静态 加载
- bitmap与uri互相转换
- Spring框架入门
- 数据中心网络拥塞控制分析之TIMELY