了解堆和栈
2016-03-17 18:47
246 查看
程序的内存分配
一个由C/C++编译的程序占用的内存分为以下几个部分1、栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
2、堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。
3、全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 - 程序结束后有
系统释放
4、文字常量区 —常量字符串就是放在这里的。 程序结束后由系统释放
5、程序代码区—存放函数体的二进制代码。
堆栈缓存方式
栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放。存取速度较快。堆则是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定(并不是一旦成为孤儿对象就能被回收)。所以调用这些对象的速度要相对来得低一些。
通常函数参数,返回值,局部变量,已知变量类型(int、float等)分配在栈上
自己new、malloc、alloc或者自定义类,系统不知道多大的分配在堆上
值类型是分配在栈里面,引用类型分配在堆里面。
看看这篇文章吧:http://kb.cnblogs.com/page/501239/
相关文章推荐
- SecureCRT通过脚本实现自动化登录
- Linux 基础命令2
- ubuntu上按文件名查找并替换文件内容
- M
- 1013_三角形判断
- mount命令详解
- SQL 查询 逗号 分割的属性值
- SecureCRT通过脚本实现自动化登录
- 新手上路之Hibernate:第一个Hibernate例子
- angularJS过滤器和自定义的过滤器
- [Android M] Bluedroid修改蓝牙默认名称
- GO语言练习:构建json 和 解析JSON 实例
- Servlet3.0 异步 servlet Comet 技术
- 蓝桥杯 国王的烦恼 反向并查集
- 二叉查找树模版
- 复利计算3.0 心得
- python 根据现有文件树创建文件树
- vmware.c:1226: error: ‘XML_PARSE_HUGE’ undeclared (first use in this function)
- 人如流水
- STL(map和二维map/hdu1263)