一、JVM整体架构
JVM(虚拟机)指以软件的方式模拟具有完整硬件系统功能、运行在一个完全隔离环境中的完整计算机系统,是物理机的软件实现。常有的虚拟机有VMware、Virtual Box、Java Virtual Machine、Docke等。
Java虚拟机阵营:Sun HotSpot VM、BEA JRockit VM、IBM J9 VM、Azul VM、Apacher Harmony、Google Dalvik VM、Microsoft JVM等。
二、java运行原理
三、运行时数据区(JVM内存模型)
- 本地方法栈(线程私有):登记native方法,在Exception Engine执行时加载本地方法库。
- 程序计数器(线程私有):就是一个指针,指向方法区中方法字节码(用来存储指向下一条指令的地址,也即将要执行的指令代码),由执行引擎读取下一条指令,是一个非常小的内存空间,几乎可以忽略不计。
- 方法区(线程共享):类的所有字段和方法字节码,以及一些特殊方法,如:构造函数、接口代码也在此定义。简单说,所有定义的方法的信息都保存在该区域,静态变量+常量+类信息(构造方法/接口定义)+运行时常量池都存在方法区。
- Java栈(线程私有):Java线程执行方法的内存模型,一个线程对应一个栈,每个方法再执行的同时都会创建一个栈帧(用于存储局部变量表、操作数栈、动态链接、方法出口等信息)不存在垃圾回收问题,只要线程一结束该栈就释放,生命周期和线程一致。
- 堆(线程共享):虚拟机启动时创建,用于存放对象实例,几乎所有的对象(包括常量池)都在堆上分配内存,当对象无法在该空间申请到内存时将抛出OOM错误,同时也是垃圾收集器管理的主要区域。可以通过-Xmx -Xms参数来分别指定最大堆和最小堆。
四、整体运行过程