JVM相关知识点总结

1、基本概念

JVM是可运行Java代码的假想计算机,包括一套字节码指令集、一组寄存器、一个栈、一个垃圾回收、堆和一个存储方法域。JVM是运行与操作系统之上的,它与硬件没有直接的交互。

2、运行过程

我们都知道Java源文件,通过编译器,能够产生相应的.class文件,也就是字节码文件,而字节码文件又通过Java虚拟机中的解释器,编译成特定机器上的机器码。

①.java源文件 -> 编译器 ->字节码文件

②.字节码文件 -> JVM -> 机器码

每一种平台的解释器是不同的,但实现的虚拟机是相同的,这也就是为什么Java能够跨平台的原因。当一个程序从开始运行,这时虚拟机就开始实例化了,多个程序启动就会存在多个虚拟机实例。程序退出或关闭,则虚拟机实例消亡,多个虚拟机实例之间数据不能共享。

2.1.线程

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

Hotspot JVM 后台运行的系统线程主要有:

虚拟机线程
VM Thread

这个线程等待JVM到达安全点操作出现。这些操作必须要在独立的线程李执行,因为当堆修改无法进行时,线程都需要JVM位于安全点。

这些操作类型有:stop-the-world 垃圾回收,线程栈 dump,线程暂停,线程偏向锁(biased Locking)解除。

周期性任务线程这线程负责定时器事件(也就是中断),用来调度周期性操作的执行。
GC线程这些线程支持JVM中不同的垃圾回收活动
编译器线程这些线程在运行时动态的将字节码编译成本地平台相关的机器码
信号分发线程这个线程接收发送到JVM的信号,并调用适当的 JVM 方法处理了

 

 

 

 

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值