jvm系统架构图

                                                                jvm系统架构图

                                                                注:灰色部分为线程私有,占用空间较小

一、类装载器(Class loader)

     虚拟机自带的加载器

  1. 启动类加载器(Bootstrap)C++
  2. 扩展类加载器(Extension)Java
  3. 应用程序类加载器(AppClassLoader),Java也叫系统类加载器,加载当前应用的classpath的所有类

    用户自定义加载器

  1. Java.lang.ClassLoader的子类,用户可以定制类的加载方式

     扩展知识点

  • 双亲委派:类的加载过程都是先交给父类去加载,当父类无法找到加载所需的class时,子类才会去尝试自己加载。为了防止原始被定义的一些类被污染,保证沙箱安全机制

 

二、本地方法栈(Native Method Stack)、本地方法接口(Native Interface)

  • 本地方法接口(Native Interface):作用是融合不同的编程语言为Java所用,它的初衷是融合C/C++程序,Java诞生的时候是C/C++横行的时候,要想立足,必须有调用C/C++程序,于是就在内存中专门开辟了一块区域处理标记为native的代码,它的具体做法是Native Method Stack中登记native方法,在Execution Engine执行时加载native libraies。     目前,该方法使用的越来越少了,除非是与硬件有关的应用,比如通过Java程序驱动打印机或者Java系统管理生产设备,在企业级应用中已经比较少见。因为当前在异构的系统间通信已经非常发达,比如可以使用socket通信、Web Service等等。
  • 本地方法栈(Native Method Stack):用来登记native方法,在Execution Engine执行时加载本地方法库。

 

三、程序计数器(Program Counter Register)

         每个线程都有一个程序计数器,是线程私有的,就是一个指针,指向方法区中的方法字节码(用来存储指向下一条指令的地址,也就是即将要执行的指令代码),由执行引擎读取下一条指令,是一个非常小的内存空间,几乎可以忽略不计。

如果执行的是一个Native方法,那这个计数器是空的。

用以完成分支、循环、跳转、异常处理、线程恢复等基础功能。不会发生内存溢出(OutOfMemory OOM)。

 

jvm系统架构图

上一篇:1. 两数之和_简答_数组


下一篇:java中queue的常用方法