什么是JVM
JVM(Java Virtual Machine)叫做Java虚拟机。jvm是Java运行基础。java虚拟机时一个可以执行Java字节码的虚拟机进程。Java源文件被编译成能被Java虚拟机执行的字节码文件。Java被设计成应用程序可以运行在任何平台(平台无关性),Java虚拟机让这个变为可能。
JVM内存模型
JVM内存分为线程私有区和线程共享区
线程私有区
方法区(Method Area)
线程共享的,用于存放被虚拟机加载的类的元数据信息,如常量、静态变量和即时编译器编译后的代 码。若要分代,算是永久代(老年代),以前类大多“static”的,很少被卸载或收集,现回收废弃常量和 无用的类。其中运行时常量池存放编译生成的各种常量。(如果hotspot虚拟机确定一个类的定义信息 不会被使用,也会将其回收。回收的基本条件至少有:所有该类的实例被回收,而且装载该类的 ClassLoader被回收)
Java堆(Java Heap)
存放对象实例和数组,是垃圾回收的主要区域,分为新生代和老年代。刚创建的对象在新生代的Eden 区中,经过GC后进入新生代的S0区中,再经过GC进入新生代的S1区中,15次GC后仍存在就进入老年 代。这是按照一种回收机制进行划分的,不是固定的。若堆的空间不够实例分配,则 OutOfMemoryError。
程序计数器(Program Count Register)
当同时进行的线程数超过CPU数或者其内核数时,就要通过时间片轮询分派CPU的时间资源,不免发生线程转换。这时,每个线程就需要一个属于自己的计数器来记录下一条要运行的指令。如果执行的是Java方法,计数器记录正在执行的java字节码地址,如果执行的是native方法,则计数器为空。
线程共享区
虚拟机栈(VM Stack)
虚拟机栈是线程私有的,与线程在同一时间创建。每个方法执行时都会创建一个桢栈来存储方法的变量表、操作数栈、动态链接方法、返回值、返回地址信息等信息。栈的大小决定了方法调用的可达深度(递归多少层次,或嵌套调用多少层其他方法,-Xss参数可以设置虚拟机栈大小。栈的大小可以固定,或者动态扩展。如果请求的栈深度大于最大可用深度,则抛出 stackOverflowError;如果栈是可动态扩展的,但没有内存空间支持扩展,则抛出 OutofMemoryError
本地方法栈(Native Method Stack)
与虚拟机栈作用相似。但它不是为Java方法服务的,而是本地方法(C语言)