JVM系列 运行时数据区

9 篇文章 0 订阅 ¥199.90 ¥299.90
13 篇文章 11 订阅
5 篇文章 4 订阅
本文详细介绍了JVM的运行时数据区,包括堆、虚拟机栈、方法区、本地方法栈、程序计数器和直接内存。堆分为新生代和年老代,新生代又包括Eden和Survival区。虚拟机栈每个线程都有一个,用于存储局部变量、操作数栈等。方法区存储类信息、常量和静态变量。直接内存虽然不在JVM规范中,但在NIO中扮演重要角色,可能导致OutOfMemoryError。
摘要由CSDN通过智能技术生成

系列文章目录

第一章 运行区实验



前言

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字符串常量池。

<

  • 23
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 34
    评论
评论 34
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

青花科技

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值