第一章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运行时数据区的一部分,但在并发编程中被频繁使用