您的位置:首页 > 其它

【JVM】——内存模型

2017-08-06 20:38 113 查看
(一)总体架构图



(二)简介

程序计数器:当前线程执行的字节码的行号指示器。线程私有。

java虚拟机栈:线程私有。虚拟机栈描述的是虚拟机执行Java方法执行的内存模型:每个方法被执行的时会同时创建一个栈帧(Stack
Frame ①)用于存储局部变量表、操作栈、动态链接、方法出口等信息。
局部变量表:存放编译期可知的基本数据类型(boolean、byte、char、short、int、float、long、double)、对象引用reference
类型

本地方法栈:线程私有。描述的是虚拟机使用到的Native方法服务。

Java堆:所有线程共享的。虚拟机启动时创建。
目的:存放对象实例,几乎所有的对象实例都在这里分配内存。

Java堆是垃圾收集器管理的主要区域。也称GC堆
收集器基本都采用分代收集算法。Java堆可分为新生代和老年代。

方法区
所有线程共享。

用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据

运行时常量池
是方法区的一部分。Class 文件中除了有类的版本、字段、方法、接口等描述等信息外,还有一项信息是常量池(Constant PoolTable),用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后存放到方法区的运行时常量池中。

直接内存:NIO可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java
堆里面的DirectByteBuffer 对象作为这块内存的引用进行操作。这样能在一些场景中显著提高性能,因为避免了在Java 堆和Native 堆中来回复制数据。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: