系列文章目录
文章目录
前言
JVM(Java虚拟机)运行区是Java程序在运行过程中被JVM所管理的内存区域。它包括了Java程序运行时的堆(Heap)、栈(Stack)、方法区(Method Area)、本地方法栈(Native Method Stacks)、程序计数器和直接内存(Direct Memory)等部分。

一、堆(Heap)
堆(Heap)是Java程序运行时用于动态分配内存的区域,也是Java垃圾收集器进行垃圾回收的主要区域。堆内存被所有线程共享。
以JDK8为例,堆(Heap)用来存放对象,几乎所有(逃逸分析技术,栈上分配、标量替换)对象都在堆上分配,将Java堆细分的目的只是为了更好地回收内存,或者更快地分配内存,堆中没有内存分配对象,并且无法扩展时,会抛出OutOfMemoryError异常。
堆(Heap)一般管理新生代/Young区 、年老代(old区) 、String字符串常量池。
1.1、新生代/Young区
新生代里包含Eden区 与 Survival区2个区。
1.1.1、Eden区
Eden区位于Java堆的年轻代,是新对象分配内存的地方,由于堆是所有线程共享的,因此在堆上分配内

本文详细介绍了JVM的运行时数据区,包括堆、虚拟机栈、方法区、本地方法栈、程序计数器和直接内存。堆分为新生代和年老代,新生代又包括Eden和Survival区。虚拟机栈每个线程都有一个,用于存储局部变量、操作数栈等。方法区存储类信息、常量和静态变量。直接内存虽然不在JVM规范中,但在NIO中扮演重要角色,可能导致OutOfMemoryError。
订阅专栏 解锁全文
1522

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



