JVM 综述

作者: 莫那一鲁道 | 来源:发表于2018-02-16 20:18 被阅读37次

概览

从 JVM 的总体上看,它解决了3个问题:

  1. Java 程序的内存管理(GC & 运行时数据区)。
  2. Java Class 二进制字节流的加载(ClassLoader)。
  3. Java 程序的执行(执行引擎)。

如下图所示:

虚拟机基本架构

在我们的日常开发中,最和我们息息相关的就是1和2了,比如 GC 调优,内存故障排查,再比如使用自定义的类加载器去实现一些特定的逻辑,就如我们之前分析的 tomcat 源码中的类加载器用于隔离不同版本的相同类库,必须要使用自定义的类加载器。

1. Java 程序的内存管理(GC & 运行时数据区)

1.1. 运行时数据区

从上图中可以看出,虚拟机内存管理主要由几个部分组成:

  1. Java 堆(存放对象的地方)
  2. Java 栈(在 HotSpot 实现中,本地方法栈和虚拟机栈合二为一)
  3. PC 寄存器(也称为程序计数器)
  4. 方法区(JDK8 中已经将方法区去除,改为元数据区,解决了方法区----也称为永久代的内存溢出)。
  5. 直接内存(大小不限制于 Java 堆,直接向操作系统申请,使用场景于读写频繁的场合,例如 NIO)

1.2. 垃圾回收系统

Java 程序员之所以不需要显式的释放内存,一切都归功于 GC,GC 解放了 Java 程序员的双手。GC 系统会在后台清除无用的实例对象,释放内存空间。

而 JVM 中的 GC 可谓是一个庞大的系统,其中分为几个部分:

  1. 判断什么是垃圾对象
  2. 垃圾回收算法
  3. 各种各样的垃圾收集器

我们将会在后面慢慢讲解。

2. Java Class 二进制字节流的加载(ClassLoader)

2.1 类加载器

对于 Java 虚拟机来说,Class 文件是一个重要的接口,无论使用何种语言进行软件开发,只要能将源文件编译为正确的 Class 文件,那么这种语言就可以在 Java 虚拟机上运行。可以说,Class 文件就是虚拟机的基石。

如图所示:

各种语言都可以在 JVM 上运行

从上图可以看出,虚拟机不拘泥于 Java 语言,任何一个源文件只要能编译成 Class 文件的格式,就可以在JVM 上运行!Class 文件格式就像是一个接口,只要遵守这个接口,就能够在 JVM 上运行。

2.2 类加载器的工作流程

Class 文件通常是以文件的方式存在(任何二进制流都可以是 Class 类型),但只有能被 JVM 加载后才能被使用,才能运行编译后的代码。系统装在 Class 类型可以分为加载,链接和初始化三个步骤。其中,链接也可分为验证,准备和解析3步骤。如图所示:

Class 文件转载过程

2.3 类装载的条件

JVM 不会无故装载 Class 文件,只有在必要的时候才装载,哪几个时候呢?

  1. 当创建一个类的实例是,比如使用 new 关键字,或者通过反射,克隆,反序列化。
  2. 当调用类的静态方法时,即当使用字节码 invokstatic 指令。
  3. 当使用类或接口的静态字段时(final 常量除外),比如,使用 getstatic 或者 pustatic 指令。
  4. 当时用 Java.lang.reflect 包中的方法反射类的方法时。
  5. 当初始化子类,要求先初始化父类。
  6. 作为启动虚拟机,含有 main()方法的那个类。

以上6种情况属于主动调用,主动调用会触发初始化,还有一种情况是被动调用,则不会引起初始化。

2.4 类加载器的双亲委派模型

先来看一个著名的图:

类加载器双亲委派模型

虚拟机为了保护应用程序内出现多个类名相同的类对象,因此发明了这个机制:当 JVM 需要适用一个类时,在判断类是否已经被加载时,会先从当前底层类加载器进行判断。当系统需要加载一个类时,会从顶层类开始加载,依次向下尝试,知道成功,否则抛出ClassNotFound 异常。

# 总结

这篇文章主要是为了后面的详细文章做一个大纲,因此只是讲述以 JVM 的一些基本的框架和概念,后面讲详细的讲述内部细节。让我们学习虚拟机更加的有条理。

相关文章

  • JVM 综述

    概览 从 JVM 的总体上看,它解决了3个问题: Java 程序的内存管理(GC & 运行时数据区)。 Java ...

  • JVM综述

    关键词:java字节码、java类加载机制、jvm内存模型、jvm垃圾回收机制 ZERO 持续更新 请关注:ht...

  • 九神带你入门JVM(上)

    概述 本篇较长,九神带你从0入门JVM,全文包括包括JVM的分类、JVM垃圾回收综述、JVM的内存模型(Java ...

  • 深入浅出 JVM ClassLoader

    # 前言 在 JVM 综述里面,我们说,JVM 做了三件事情,Java 程序的内存管理,Java Class 二进...

  • JVM篇1:[-结构综述-]

    一、几个概念简介 1.JDK、JRE、JVM 有了JRE就能运行java程序,如果只是运行软件,装个JRE就行了。...

  • 九神带你入门JVM(下)

    我们接着上面一篇继续学习JVM的基本知识。 对象存活判断 上篇中我们介绍过JVM垃圾回收综述中说过一次垃圾回收之后...

  • 文献综述之细则集

    1. 文献综述文献综述是写论文时经常用到的方法,可以迁移到很多地方。例如,竞品综述、客户需求综述、运营综述、...

  • 转发股评

    【综述】2019.8.19——好戏 原创: 张德良 德良综述 昨天 【综述】2019.8.19——好戏 张德良SA...

  • 文献综述——站在巨人的肩膀上

    站在巨人的肩膀上。 文献综述, 欢迎来到 论文文献综述课 一、文献综述的概念 ○ 文献综述是针对某一研究领域或专题...

  • 转发财经

    【综述】2019.4.15——平和 张德良 德良综述 今天 【综述】2019.4.15——平和 张德良SAC证书S...

网友评论

    本文标题:JVM 综述

    本文链接:https://www.haomeiwen.com/subject/eayptftx.html