程序运行时内存区域使用与管理
2017-02-19 22:46
274 查看
内存可以分为栈区、堆区、全局区、文字常量区、程序代码区,其使用与管理如下:
1、栈区(stack),它由编译器自动分配和释放,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈;
2、堆区(heap),它一般由程序员分配和释放,若程序员不释放,程序结束时可能操作系统释放回收。注意,它与数据结构中的堆是两回事,分配方式类似于链表;
3、全局区(静态区static),全局变量和静态变量的存储是放在一起的,初始化的全局变量和静态变量在同一块区域,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域,程序结束后由系统释放。
4、文字常量区,常量字符串就是放在这个区上。程序结束后由系统释放。
5、程序代码区,存放函数体的二进制代码。
1、栈区(stack),它由编译器自动分配和释放,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈;
2、堆区(heap),它一般由程序员分配和释放,若程序员不释放,程序结束时可能操作系统释放回收。注意,它与数据结构中的堆是两回事,分配方式类似于链表;
3、全局区(静态区static),全局变量和静态变量的存储是放在一起的,初始化的全局变量和静态变量在同一块区域,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域,程序结束后由系统释放。
4、文字常量区,常量字符串就是放在这个区上。程序结束后由系统释放。
5、程序代码区,存放函数体的二进制代码。
相关文章推荐
- 2、使用 uboot 下载程序到内存并运行
- 使用CLR Profiler查看C#运行程序的内存占用情况
- HDFS设计思路,HDFS使用,查看集群状态,HDFS,HDFS上传文件,HDFS下载文件,yarn web管理界面信息查看,运行一个mapreduce程序,mapreduce的demo
- Java虚拟机管理的内存运行时数据区域解释
- 程序的运行在内存中有5个区域
- Qt使用windows API获取程序运行时占用内存 good
- 自动内存管理机制_运行时数据区域
- Java程序运行前后内存使用情况
- C/C++程序编译时和运行时内存区域分配
- 一个完整的Java程序运行过程会涉及以下内存区域
- C++ 测量程序运行时间 任务管理看内存
- 使用memory_profiler 与 cProfile ,line_profiler 优化Python程序运行时间和内存消耗实例
- 程序运行时内存的使用
- C# ASP.NET 优化程序性能、降低内存使用、提高程序运行速度
- 详解Java虚拟机管理的内存运行时数据区域
- JVM内存管理机制--运行时数据区域(详解)
- HDFS设计思路,HDFS使用,查看集群状态,HDFS,HDFS上传文件,HDFS下载文件,yarn web管理界面信息查看,运行一个mapreduce程序,mapreduce的demo
- JVM内存管理机制--运行时数据区域(详解)
- Java虚拟机管理的内存运行时数据区域解释