offer来了笔记-(原理篇)

第一章jvm

1.1 JVM的运行机制

java文件被编译成.class字节码文件,jvm将字节码文件翻译成机器能够识别的机器码,机器码调用相应操作系统的本地方法库执行相应的方法。

jvm包括一个类加载子系统,运行时数据区,执行引擎,本地接口库,本地接口库通过本地方法库与操作系统交互

类加载器将编译好的.class文件加载进jvm
运行时数据库存储jvm运行时产生的数据包括程序计数器,方法区(常量池),堆,栈,本地方法区。
执行引擎包括垃圾回收和即使编译器,垃圾回收是回收运行过不再使用的对象,即时编译器是将字节码编译成对应的机器码
本地接口库用于调用操作系统的本地方法库完成具体的指令操作

1.2 多线程

在JVM线程的本地存储、缓冲区分配、同步对象、栈、程序计数器等准备工作都完成时,JVM会调用操作系统的接口创建一个与之对应的原生线程;在JVM线程运行结束时,原生线程随之被回收。操作系统负责调度所有线程,并为其分配CPU时间片,在原生线程初始化完毕时,就会调用Java线程的run()执行该线程;在线程结束时,会释放原生线程和Java线程所对应的资源。
在JVM后台运行的线程主要有以下几个。◎ 虚拟机线程(JVM Thread):虚拟机线程在JVM到达安全点(SafePoint)时出现。◎ 周期性任务线程:通过定时器调度线程来实现周期性操作的执行。◎ GC线程:GC线程支持JVM中不同的垃圾回收活动。◎ 编译器线程:编译器线程在运行时将字节码动态编译成本地平台机器码,是JVM跨平台的具体实现。◎ 信号分发线程:接收发送到JVM的信号并调用JVM方法。
在这里插入图片描述

1.2 JVM的内存区域

jvm内存区域分为线程私有区域(程序计数器,本地方法区,栈),线程共享区域(堆,方法区)和直接内存
线程私有区域随线程启动而创建,随线程毁灭而消失,生命周期和线程一样
在JVM内,每个线程都与操作系统的本地线程直接映射,因此这部分内存区域的存在与否和本地线程的启动和销毁对应。

线程共享区域随虚拟机的启动而创建,随虚拟机的关闭而销毁

直接内存也叫作堆外内存,它并不是JVM运行时数据区的一部分,但在并发编程中被频繁使用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

yzhao666

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

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

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

打赏作者

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

抵扣说明:

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

余额充值