Java虚拟机(JVM)是在一台真正的机器上用软件方式实现的一台假想机,操作系统装入JVM是通过jdk中Java.exe来完成。
JVM为CPU解释编译的字节码,使其能够执行Java程序的指令。
JVM可以以一次一条指令的方式来解释字节码把它映射到实际的处理器指令,或者字节码也可以由即时编译器进行进一步的编译。
JVM有两种机制,一个叫做类装载机制(负责装载类或接口的);另一个叫做执行引擎机制(负责执行包含在已装载的类或接口中的指令)。
虚拟机内存包括五个部分:方法区、堆、程序计数器、栈、本地方法栈。
虚拟机内存和类装载机制与执行引擎机制一起组成的体系结构图为:
JVM是Java程序运行的环境,是操作系统的一个应用程序的一个进程。因此也有自己运行的生命周期,也有自己的代码和数据空间。
JVM存储模型遵循的原则包括:所有的变量都存储在主内存中(虚拟机内存的一部分);每条线程都由自己的工作内存,线程的工作内存中保存了该线程使用到的变量的主内存副本拷贝,线程对变量的所有操作都必须在工作内存中进行,而不能直接读写主内存中的变量;线程之间无法直接访问对方的工作内存中的变量,线程间变量的传递均需要通过主内存来完成。
因为多个线程间公用同一个主内存区,并且JVM在底层设计上,对于那些没有同步到主存里的变量,可能会以不一样的操作顺序来执行指令,所以出现线程安全的问题。
线程安全的类可以通过以下手段来满足:
- 不跨线程共享变量,就是将共享变量封闭在本线程内访问
- 使状态变量为不可变的
- 在任何访问状态变量的时候使用同步
- 每个共享的可变变量都需要由唯一一个确定的锁保护