【Java】线程共享的JVM内存区域有哪些

1.堆

几乎所有对象实例被分配到这里,也是垃圾收集器管理的主要区域。
Java堆可以被分为新生代和老生代。
进一步划分,则有Eden空间、From Survivor空间、To Survivor空间等。
无论如何划分,都是为了更好地回收内存、更快的分配内存。

2. 方法区

方法区由于存储虚拟机加载的类的信息、常量、静态变量、JIT编译后的代码等。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVM 内存区域可以分为以下几个部分: 1.程序计数器:是一块较小的内存区域,它可以看作是当前线程所执行的字节码的行号指示器。每个线程都有自己的程序计数器,并且任何时候一个线程都只会执行它自己的程序计数器。 2.虚拟机栈:也是线程私有的,它描述的是 Java 方法执行的内存模型。每个方法在执行时都会创建一个栈帧,用于存储局部变量表、操作数栈、方法出口等信息。虚拟机栈的大小可以通过 -Xss 参数进行设置。 3.堆:是 Java 虚拟机所管理的内存中最大的一块,被所有线程共享。堆被用来存储对象实例和数组。堆可以分为新生代和老年代,每个部分又可以进一步细分为 Eden 区、From Survivor 区、To Survivor 区和 Tenured/Old 区等。 4.方法区:也是被所有线程共享的,它用于存储已经被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。方法区也被称为永久代,但在 JDK 8 中已经被移除,取而代之的是元空间。 5.运行时常量池:是方法区的一部分,用于存储编译期生成的各种字面量和符号引用。在 Java 7 及以前版本,运行时常量池也是方法区的一部分,但在 Java 8 中,运行时常量池已经被移除,取而代之的是元空间中的 interned Strings。 6.直接内存:不是 JVM 运行时数据区的一部分,但是这部分内存也被频繁地使用。直接内存是使用 ByteBuffer 类来操作的,它可以直接分配在本地内存中,并且可以通过 Native 函数库直接访问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值