1.内存模型 & 分区
Java虚拟机在运行Java程序时,会管理着一块内存区域:运行时数据区
在运行时数据区里,会根据用途进行划分:
-
Java虚拟机栈(栈区)
-
本地方法栈
-
Java堆(堆区)
-
方法区
-
程序计数器

下面,我将详细介绍每个内存模型分区
2.Java堆

简介

3. Java虚拟机栈

简介

4. 本地方法栈

简介:十分类似Java虚拟机栈,与Java虚拟机区别在于:服务对象,即Java虚拟机栈为执行 Java 方法服务;本地方法栈为执行 Native方法服务
5.方法区

简介

注:其内部包含一个运行时常量池,具体介绍如下:

6.程序计数器

简介

7. 额外知识:直接内存
-
定义:NIO类(JDK1.4引入)中基于通道和缓冲区的I/O方式 通过使用Native函数库 直接分配 的堆外内存
-
特点:不受堆大小限制 不属于虚拟机运行时数据区的一部分 & 不在堆中分配
-
应用场景:适用于频繁调用的场景 通过一个 存储在Java堆中的DirectByteBuffer对象 作为这块内存的引用 进行操作,从而避免在 Java 堆和 Native堆之间来回复制数据,提高使用性能
-
抛出的异常:OutOfMemoryError,即与其他内存区域的总和 大于 物理内存限制
Java学习视频
Java基础:
Java300集,Java必备优质视频_手把手图解学习Java,让学习成为一种享受
Java运行时内存模型详解
本文详细介绍了Java运行时数据区的各个组成部分,包括Java虚拟机栈、本地方法栈、Java堆、方法区(包含运行时常量池)、程序计数器,以及额外的知识——直接内存。Java虚拟机栈服务于Java方法的执行,而本地方法栈则服务于Native方法。方法区存储类信息,运行时常量池用于存放各类常量。程序计数器记录当前线程执行的字节码指令地址。直接内存使用NIO类在堆外分配,提高性能,但可能导致OutOfMemoryError。
1439

被折叠的 条评论
为什么被折叠?



