01-1 JVM-线程与内存区域

系列文章目录

01-1 JVM-线程与内存区域



一、线程

这里所说的线程指程序执行过程中的一个线程实体。JVM允许一个应用并发执行多个线程。Hotspot JVM中的Java线程与原生操作系统线程有直接的映射关系。当线程本地存储、缓冲区分配、同步对象、栈、程序计数器等准备好以后,就会创建一个操作系统原生线程。Java线程结束,原生线程随之被回收。操作系统负责调度所有线程,并把它们分配到任何可用的CPU上。当原生线程初始化完毕,就会调用Java线程的run()方法。当线程结束时,会释放原生线程和JAVA线程的所有资源。


二、内存区域

在这里插入图片描述
在这里插入图片描述
线程共享区随着虚拟机的启动/关闭而创建/销毁。

1.程序计数器(线程私有)

指当前线程所执行的字节码的行号指示器,如果执行java方法,记录的是虚拟机字节码指令的地址,如果是Native方法,则为空。
ps:虚拟机中唯一不存在OOM的区域。

2.虚拟机栈(线程私有)

描述java方法执行的内存模型,每个方法在执行的同时都会创建一个栈帧(Stack Frame),包含局部变量表、操作数栈、动态链接、方法出口。每一个方法从调用到执行完成的过程,对应着一个栈帧在虚拟机栈出栈入栈的过程。
在这里插入图片描述

3.本地方法区(线程私有)

类似于虚拟机栈,专门为Native方法服务的方法栈。HotSpot VM将虚拟机栈和本地方法栈合二为一。

4.堆(线程共享)

创建的对象和数组都保存在Java堆内存中,是垃圾收集器进行垃圾收集的最重要的内存区域。堆从GC的角度还可以细分为:新生代和老年代,其中新生代可继续细分为(Eden区、From Survivor区、To Survivor区)。

5.方法区/永久代(线程共享)

用于存储被JVM加载的类信息、常量、静态变量、即时编译器编译后的代码。HotSpot VM把GC分代收集扩展至方法区,使用Java堆的永久代来实现方法区,方便统一管理。永久代的回收一般是针对常量池的回收和类型卸载,收益较小,没必要专门开发内存管理。
运行时常量池(Runtime Constant Pool)是方法区的一部分。Class文件的常量池里的信息会在类加载后存放到方法区的运行时常量池中,包含编译器生成的各种字面量和符号引用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值