三-运行时数据区概述及线程

3.1 前言

运行时数据区的完整图

灰色的为单独线程私有的,红色的为多个线程共享的。

每个线程:独立包括程序计数器、栈、本地栈
线程间共享:堆、堆外内存(永久代或者元空间、代码缓存)

私有和共享

3.2 线程

线程是一个程序里的运行单元,JVM允许一个应用有多个线程并行的执行。
在Hotspot JVM里,每个线程都与操作系统的本地线程直接映射

  • 当一个Java线程准备号执行后,此时一个操作系统的本地线程也同时创建。Java线程执行结束后,本地线程也会回收
  • 操作系统负责所有线程的安排调度到任何一个可用的CPU上。一旦本地线程初始化成功,他就会调用Java线程中的run()方法

JVM系统线程
使用jconsole等调试工具,可以看到后台许多线程。这些后台线程不包括调用public static void main(String[])的main线程以及所有这个main线程自己创建的线程。

后台系统线程在Hotspot JVM中主要是:

  1. 虚拟机线程:需要JVM到达安全点才会出现。必须在不同的线程中发送的原因是他们都需要JVM达到安全点,这样堆才不会变化。这些线程的执行类型包括"stop-the-world"的垃圾收集,线程栈收集,线程挂起以及偏向锁撤销
  2. 周期任务线程:时间周期时间的体现,一般用于周期性操作的调动执行
  3. GC线程:对JVM里不同类型的垃圾收集行为提供了支持
  4. 编译线程:将字节码编译成本地代码
  5. 信号调度线程:接受信号并发送给JVM,在他内部通过调用适当的方法进行处理
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值