博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java 内存区域
阅读量:4464 次
发布时间:2019-06-08

本文共 1013 字,大约阅读时间需要 3 分钟。

根据《Java虚拟机规范(Java SE 7版)》的规定,Java虚拟机所管理的内存将会包括以下几个运行时数据区域。(图片截取自《深入理解jvm虚拟机》)

程序计数器(PC):一块较小的内存空间,用于记录当前线程执行的自己码的位置。在JVM的概念模型中,程序的分支,循环,跳转,线程恢复等都需要使用PC。JVM多线程通过多线程轮流切换并分配处理器时间的方式实现的。任何时间同一个处理器仅执行一条指令。如果执行的class的字节码,PC记录当前执行的指令的地址;如果时native方法,则为空。

Java虚拟机栈:线程私有,生命周期和线程相同。这个区域描述的时java方法执行的内存模型,每个方法执行的时候会创造一个栈帧,存储局部变量表、操作数栈、动态链接、方法出入口等信息。每一个方法的调用都伴随着栈帧在虚拟机栈的出入栈。局部变量表存放了编译期间可以知道的各种数据结构对象引用。JVM规范种对这个区域定义了两种异常:StackOverFlowError和OutOfMemoryError。

本地方法栈:和Java虚拟机栈很相似,不同的是这里服务的是Native方法。

Java堆区:对于绝大多数应用而言,这个区域是JVM管理的最大的一个区域。虚拟机启动创建的时候,几乎所有的对象实例都存放在这里。堆区也是垃圾回收的主要区域,由于现在采用分代收集法回收垃圾,从垃圾回收的角度看,可以分为新生代和老年代,再细致一些会有Eden空间、from survivor空间、to survivor等。

方法区:方法区和堆区一样,各个线程共享。用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。

运行时常量池:是方法区的一部分。Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项就是常量池,用于存放编译器生成的各种字面量和符号引用,这部分内容在类加载后进入方法区的运行时常量池中存放。运行时常量池相对于Class文件常量池的另一个特征就是具备动态行,Java语音不要求常量一定要编译期才能产生,运行期也可以,比较常用的就是String类的intern方法。

直接内存:JDK1.4开始加入了NIO,引入了一种基于通道与缓冲区的IO方式,它可以用Native函数库直接分配堆外内存。

转载于:https://www.cnblogs.com/avalon-merlin/p/9223186.html

你可能感兴趣的文章
使用本机IP调试web项目
查看>>
【Java面试题】58 char型变量中能不能存贮一个中文汉字?为什么?
查看>>
C++ Primer 第六章 函数
查看>>
交互设计算法基础(3) - Quick Sort
查看>>
Ubuntu各种软件的安装
查看>>
Android电源管理
查看>>
C#_基础_方法以及方法重载(十)
查看>>
新起点新希望
查看>>
LINQ系列:LINQ to DataSet的DataTable操作
查看>>
ASP。net 测验
查看>>
java开发环境搭建-慕课网
查看>>
NOIP2015-D2T3运输计划
查看>>
Z :彻底了解指针数组,数组指针以及函数指针 [复
查看>>
2013年终总结
查看>>
Start to study Introduction to Algorithms
查看>>
AE常见接口之间的关系(较笼统)+arcgis常见概念
查看>>
正则表达式
查看>>
三元操作设计不同类型的时候,最终结果的问题
查看>>
POJ 1661 Help Jimmy LIS DP
查看>>
大数据时代,我诚惶诚恐的拥抱
查看>>