JVM与java体系结构

JVM的整体结构

JVM与java体系结构_第1张图片

  1. 类加载子系统:加载链接初始化class文件。
  2. 执行引擎:将字节码翻译成二进制指令,使操作系统能解析执行。还有一个部分是JIT编译器,缓存热点指令,翻译成本地机器码。
  3. 方法区:线程共享,存放类的所有字段和方法的字节码,以及一些特殊方法如构造函数,接口代码也在此定义。所有定义的方法的信息都保存在该区域,静态变量+常量+类信息(构造方法、接口定义)+运行时常量池 都存在方法区中。虽然Java虚拟机规范把方法去描述成为堆的一个逻辑部分,但是它有一个别名Non-Heap(非堆)。
  4. 堆:线程共享,虚拟机启动时创建,用于存放对象实例,几乎所有对象(包含常量池)分配内存的地方,空间不够回抛出OutOfMemoryError异常。同时也是垃圾回收器管理的主要区域。
  5. java栈:又叫虚拟机栈,线程私有,Java线程执行方法的内存模型,一个线程对应一个栈,每个方法在执行的同时都会创建一个栈帧(用于存储局部变量表,操作数栈,动态链接,方法返回地址、一些附加信息),不存在垃圾回收,只要线程一结束该站就释放,生命周期和线程一致。该区域有两种异常:
    1.  线程请求的栈深度大于虚拟机栈所允许的深度,将抛出StackOverFlowError异常。

    2. 若虚拟机栈可动态扩展,当无法申请到足够内存空间时将抛出OutOfMemoryError,通过jvm参数–Xss指定栈空间,空间大小决定函数调用的深度。

  6. 本地方法栈:线程私有,在执行引擎执行时,加载本地方法库。本地方法:由native修饰的方法,主要用于链接其他语言实现的方法。
  7. 程序计数器:线程私有,就是一个指针,指向方法区中方法字节码(用来存储指向下一条指令的地址),由执行引擎读取下一条指令,是一个非常小的内粗你空间,几乎可以忽略不记。

JVM与java体系结构_第2张图片

你可能感兴趣的:(JVM,java,开发语言,后端)