原文地址: http://coderbee.net/index.php/java/20131017/512
《深入理解Java虚拟机:JVM高级特性与最佳实践》-笔记
JVM运行时数据区
根据《Java虚拟机规范》,JVM管理的内存如下:
图片来自网络。
其中绿色部分是所有JVM线程共享的,黄色部分是线程独立的。
程序计数器
记录正在执行的虚拟机字节码指令的地址,如果执行的本地方法,则值为未定义。
方法区
存储已加载类信息、常量、静态变量、即时编译器编译后的代码等数据。
HotSpot虚拟机把方法区称为永久代。
运行时常量池是方法区的一部分,用于存放编译期生成的各种字面量和符号引用。相对于Class文件常量池的一个特征是具备动态性,可在运行时把常量放入池中,如通过String.intern方法。
虚拟机栈
描述Java方法执行的内存模型:每个方法在执行时都会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每个方法的调用和完成都对应一个栈帧在栈上的入栈和出栈。
局部变量表存放编译期可知的基本数据类型、对象引用、returnAddress类型。所需内存空间在编译期完成分配,在运行期不变。
当虚拟机无法创建栈帧时抛出StackOverflowError错误。
本地方法栈
与虚拟机栈帧作用类似,为本地方法服务。
Java堆
存放对象实例及数组。垃圾回收发生的主要地方。
对象的内存布局
在虚拟机实现里,一个对象的内存布局包括:对象头、实例数据、对齐填充。
HotSpot虚拟机的对象头包括两部分信息:
-
存储对象自身的运行时数据,如哈希码、GC分代年龄、锁状态标志、线程持有的锁、偏向线程ID、偏向时间戳等,这部分数据称为“Mark Word”。是非固定格式的。
-
类型指针,指向对象所属类型的元数据,虚拟机通过这个指针来确定这个对象是哪个类的实例。
对象的访问定位
一般有两种方式:
-
句柄:每个句柄包含了对象实例数据与类型数据各自具体地址信息。访问对象数据需要2次定位,在垃圾回收移动对象后,只需要修改句柄的值,不需要修改栈上对象引用的值。
-
直接指针:直接指向对象实例数据的地址,对象实例数据含有指向对象类型数据的地址。
相关推荐
第3节: 揭秘JVM运行时数据区-02第3节: 揭秘JVM运行时数据区-02第3节: 揭秘JVM运行时数据区-02第3节: 揭秘JVM运行时数据区-02第3节: 揭秘JVM运行时数据区-02第3节: 揭秘JVM运行时数据区-02第3节: 揭秘JVM运行...
### JVM运行时数据区详解 #### 一、概述 Java虚拟机(JVM)作为Java程序的运行环境,定义了一系列用于程序执行过程中使用的数据区域。这些数据区域在JVM启动时创建,在JVM退出时销毁。其中一些数据区域是线程独立...
Java内存模型与JVM运行时数据区的区别详解 Java内存模型是Java语言在多线程并发情况下对于共享变量读写的规范,主要是为了解决多线程可见性、原子性的问题,解决共享变量的多线程操作冲突问题。Java内存模型是为了...
JVM运行时数据区原理解析 JVM运行时数据区是Java虚拟机中最重要的组成部分之一,它是JVM运行时的核心区域,负责存储和管理程序运行时需要的数据。根据JVM规范,JVM运行时数据区可以分为五个部分:PC寄存器、虚拟机...
"JVM运行时数据区划分原理详解" JVM运行时数据区划分原理详解是Java虚拟机(JVM)的核心组件之一,负责管理Java应用程序的内存资源。该原理详解了JVM如何划分和管理内存空间,以便更好地支持Java应用程序的运行。 ...
首先,我们来看JVM运行时数据区的组成部分: 1. **方法区(Method Area)**:这是一个全局共享的内存区域,存储了类信息、常量、静态变量以及编译后的代码。这部分内存被称为Non-Heap,当其内存不足时,会抛出`...
此外,直接内存不属于JVM运行时数据区的一部分,但被频繁使用,如在Java NIO中用于基于Channel与Buffer的IO操作。 3. JVM执行引擎与垃圾回收: JVM的执行引擎负责解释字节码指令,它通常包括即时编译器和解释器两种...
03 JVM 运行时数据区概述及线程的 PPT 重绘。讲述 Java 虚拟机 运行时数据区所处位置,结构划分,以及各个区域与线程的关系。
### JVM运行时数据区 #### 程序计数器 程序计数器是当前线程所执行的字节码的行号指示器,是线程私有的内存区域。由于Java是多线程并发执行的,每个线程都需要有一个独立的程序计数器,以便记录线程切换后继续执行...
5. **JVM运行时数据区详解**: - 程序计数器:每个线程都有自己的计数器,用于记录当前线程正在执行的字节码指令位置。 - 虚拟机栈:存储每个方法的局部变量表、操作数栈、动态链接和方法出口等信息,每个方法调用...
直接内存并不属于JVM运行时数据区的一部分,而是由JDK NIO库直接分配的堆外内存。这部分内存不受JVM堆大小的限制,但同样可能导致内存溢出。DirectByteBuffer对象作为直接内存的引用,用于操作这块内存。 #### 三、...
#### 三、JVM运行时数据区详解 ##### 3.1 PC寄存器 PC寄存器(Program Counter Register)用于存储当前线程下一条指令的位置。对于执行native方法的线程,PC寄存器内容为空。 ##### 3.2 JVM栈 JVM栈是线程私有的...
#### 二、JVM运行时数据区 JVM在运行时会划分多个内存区域来管理数据,主要包括以下几个部分: - **方法区**:存储类的信息(包括类的方法和字段)、常量、静态变量等。 - **堆区**:用于存放所有类实例和数组对象...
6. 直接内存(Direct Memory):并非JVM运行时数据区的一部分,它通过NIO类库支持直接操作本地内存,并不是JVM规范所定义的。 JVM内存模型的设计是为了支持Java程序的动态特性,同时保证内存的安全和高效利用。JVM...
以下是对JVM运行时数据区及其相关知识点的详细说明: 1. **运行时数据区**: - **程序计数器**:每个线程都有自己的程序计数器,用于存储当前线程执行的字节码的行号,是唯一没有规定内存溢出情况的区域。 - **...
5. **JVM运行时数据区详解**: - 程序计数器:记录当前线程执行的字节码指令位置,用于控制程序流程。 - 虚拟机栈:每个方法对应一个栈帧,存储局部变量表、操作数栈、动态链接和方法返回地址等信息。 - 本地方法...
#### JVM运行时数据区 **5. JVM运行时数据区详解** JVM管理的内存主要分为以下几部分: - **程序计数器(Program Counter Register)**:记录当前线程所执行的字节码指令的位置,确保线程恢复执行时可以从正确的...
#### 二、JVM运行时数据区 ##### 2.1 堆区 堆是所有线程共享的一块内存区域,在虚拟机启动时创建。主要用于存放对象实例和数组。 - **新生代**:主要存放新创建的对象。 - **老年代**:经过多次GC后存活的对象会被...