• JVM系列之一:JVM架构


    1.简介

      Java平台可分为两部分,即Java虚拟机(Java virtual machine,JVM)和Java API类库。

      JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM使得Java实现了跨平台。

      引入Java语言虚拟机后,Java语言在不同平台上运行时不需要重新编译。Java语言使用Java虚拟机屏蔽了与具体平台相关的信息,使得Java语言编译程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。

    2. JVM架构图

      Java虚拟机主要分为五大模块:类装载器子系统、运行时数据区、执行引擎、本地方法接口和垃圾收集模块。

    各部分的主要功能:

      类加载器 :JVM启动,程序开始执行时,负责将class字节码加载到JVM内存区域中

      执行引擎 :负责执行class文件中包含的字节码指令

      本地方法库  :主要是调用C或C++实现的本地方法及返回结果

      运行时数据区【重点关注】

        方法区(Method Area) :用于存储类结构信息的地方,包括常量池、静态变量、构造函数等

        java堆(Heap) :存储java实例或者对象的地方。这块是GC的主要区域。方法区和堆是被所有java线程共享的。

        java栈(Stack) :java栈总是和线程关联在一起,每当创建一个线程时,JVM就会为这个线程创建一个对应的java栈。在这个java栈中又会包含多个栈帧,每运行一个方法就创建一个栈帧,用于存储局部变量表、操作栈、方法返回值等。每一个方法从调用直至执行完成的过程,就对应一个栈帧在java栈中入栈到出栈的过程。所以java栈是现成私有的。

        程序计数器(PC Register) :程序计数器是一块较小的内存空间,可以看作是当前线程所执行的字节码的行号指示器。分支、循环、跳转、异常处理、线程恢复等基础功能都需要依赖这个计数器来完成。

        本地方法栈(Native Method Stack) :和java栈的作用差不多,只不过是为JVM使用到的native方法服务的。

     3. JVM内部模块间的关系

    这里写图片描述

    垃圾回收系统:方法区、Java堆

    类加载器:方法区、Java堆

    执行引擎:方法区、Java堆、Java栈、PC寄存器

    摘录自

    https://note.youdao.com/ynoteshare1/index.html?id=920f10f97acfc22fe0c27cc52a97cb28&type=note

    【Java面试整理之JVM】深入理解JVM结构、类加载机制、垃圾回收GC原理、JVM内存分配策略、JVM内存泄露和溢出

  • 相关阅读:
    Dockfile编写常见命令
    coreDNS域名无法解析问题
    开源软件
    容器相关
    日常工具
    持续集成
    mysql主从同步
    生产环境MySQL5.7-my.cnf 配置文件 for linux (转)
    工作交接流程引导图
    文章记录
  • 原文地址:https://www.cnblogs.com/haimishasha/p/11229144.html
Copyright © 2020-2023  润新知