`

【优化】JVM组成

 
阅读更多
本文转自:http://thw.iteye.com/blog/953869

1 JVM 简介
JVM 是我们Javaer 的最基本功底了,刚开始学Java 的时候,一般都是从“Hello World ”开始的,然后会写个复杂点class ,然后再找一些开源框架,比如Spring ,Hibernate 等等,再然后就开发企业级的应用,比如网站、企业内部应用、实时交易系统等等,直到某一天突然发现做的系统咋就这么慢呢,而且时不时还来个内存溢出什么的,今天是交易系统报了StackOverflowError ,明天是网站系统报了个OutOfMemoryError ,这种错误又很难重现,只有分析Javacore 和dump 文件,运气好点还能分析出个结果,运行遭的点,就直接去庙里烧香吧!每天接客户的电话都是战战兢兢的,生怕再出什么幺蛾子了。我想Java 做的久一点的都有这样的经历,那这些问题的最终根结是在哪呢?—— JVM 。
JVM 全称是Java Virtual Machine ,Java 虚拟机,也就是在计算机上再虚拟一个计算机,这和我们使用 VMWare 不一样,那个虚拟的东西你是可以看到的,这个JVM 你是看不到的,它存在内存中。我们知道计算机的基本构成是:运算器、控制器、存储器、输入和输出设备,那这个JVM 也是有这成套的元素,运算器是当然是交给硬件CPU 还处理了,只是为了适应“一次编译,随处运行”的情况,需要做一个翻译动作,于是就用了JVM 自己的命令集,这与汇编的命令集有点类似,每一种汇编命令集针对一个系列的CPU ,比如8086 系列的汇编也是可以用在8088 上的,但是就不能跑在8051 上,而JVM 的命令集则是可以到处运行的,因为JVM 做了翻译,根据不同的CPU ,翻译成不同的机器语言。
JVM 中我们最需要深入理解的就是它的存储部分,存储?硬盘?NO ,NO , JVM 是一个内存中的虚拟机,那它的存储就是内存了,我们写的所有类、常量、变量、方法都在内存中,这决定着我们程序运行的是否健壮、是否高效,接下来的部分就是重点介绍之。

2 JVM 的组成部分
我们先把JVM 这个虚拟机画出来,如下图所示:



从这个图中可以看到,JVM 是运行在操作系统之上的,它与硬件没有直接的交互。我们再来看下JVM 有哪些组成部分,如下图所示:




该图参考了网上广为流传的JVM 构成图,大家看这个图,整个JVM 分为四部分:
q  Class Loader 类加载器
类加载器的作用是加载类文件到内存,比如编写一个HelloWord.java 程序,然后通过javac 编译成class 文件,那怎么才能加载到内存中被执行呢?Class Loader 承担的就是这个责任,那不可能随便建立一个.class 文件就能被加载的,Class Loader 加载的class 文件是有格式要求,在《JVM Specification 》中式这样定义Class 文件的结构:
    ClassFile {
      u4 magic;
      u2 minor_version;
       u2 major_version;
      u2 constant_pool_count;
      cp_info constant_pool[constant_pool_count-1];
      u2 access_flags;
      u2 this_class;
      u2 super_class;
      u2 interfaces_count;
      u2 interfaces[interfaces_count];
      u2 fields_count;
      field_info fields[fields_count];
      u2 methods_count;
      method_info methods[methods_count];
      u2 attributes_count;
      attribute_info attributes[attributes_count];
    }
需要详细了解的话,可以仔细阅读《JVM Specification 》的第四章“The class File Format ”,这里不再详细说明。
友情提示:Class Loader 只管加载,只要符合文件结构就加载,至于说能不能运行,则不是它负责的,那是由Execution Engine 负责的。
q  Execution Engine 执行引擎
执行引擎也叫做解释器(Interpreter) ,负责解释命令,提交操作系统执行。
q  Native Interface 本地接口
本地接口的作用是融合不同的编程语言为Java 所用,它的初衷是融合C/C++ 程序,Java 诞生的时候是C/C++ 横行的时候,要想立足,必须有一个聪明的、睿智的调用C/C++ 程序,于是就在内存中专门开辟了一块区域处理标记为native 的代码,它的具体做法是Native Method Stack 中登记native 方法,在Execution Engine 执行时加载native libraies 。目前该方法使用的是越来越少了,除非是与硬件有关的应用,比如通过Java 程序驱动打印机,或者Java 系统管理生产设备,在企业级应用中已经比较少见,因为现在的异构领域间的通信很发达,比如可以使用Socket 通信,也可以使用Web Service 等等,不多做介绍。
q  Runtime data area 运行数据区
运行数据区是整个JVM 的重点。我们所有写的程序都被加载到这里,之后才开始运行,Java 生态系统如此的繁荣,得益于该区域的优良自治,下一章节详细介绍之。

整个JVM 框架由加载器加载文件,然后执行器在内存中处理数据,需要与异构系统交互是可以通过本地接口进行,瞧,一个完整的系统诞生了!
2 JVM 的内存管理
所有的数据和程序都是在运行数据区存放,它包括以下几部分:
q  Stack 栈
栈也叫栈内存,是Java 程序的运行区,是在线程创建时创建,它的生命期是跟随线程的生命期,线程结束栈内存也就释放,对于栈来说不存在垃圾回收问题,只要线程一结束,该栈就Over 。问题出来了:栈中存的是那些数据呢?又什么是格式呢?
栈中的数据都是以栈帧( Stack Frame )的格式存在,栈帧是一个内存区块,是一个数据集,是一个有关方法 (Method) 和运行期数据的数据集,当一个方法 A 被调用时就产生了一个栈帧 F1 ,并被压入到栈中, A 方法又调用了 B 方法,于是产生栈帧 F2 也被压入栈,执行完毕后,先弹出 F2 栈帧,再弹出 F1 栈帧,遵循“先进后出”原则。
那栈帧中到底存在着什么数据呢?栈帧中主要保存3 类数据:本地变量(Local Variables ),包括输入参数和输出参数以及方法内的变量;栈操作(Operand Stack ),记录出栈、入栈的操作;栈帧数据(Frame Data ),包括类文件、方法等等。光说比较枯燥,我们画个图来理解一下Java 栈,如下图所示:




图示在一个栈中有两个栈帧,栈帧2 是最先被调用的方法,先入栈,然后方法2 又调用了方法1 ,栈帧1 处于栈顶的位置,栈帧2 处于栈底,执行完毕后,依次弹出栈帧1 和栈帧2 ,线程结束,栈释放。
q  Heap 堆内存
一个JVM 实例只存在一个堆类存,堆内存的大小是可以调节的。类加载器读取了类文件后,需要把类、方法、常变量放到堆内存中,以方便执行器执行,堆内存分为三部分:
Permanent Space 永久存储区
永久存储区是一个常驻内存区域,用于存放JDK 自身所携带的Class,Interface 的元数据,也就是说它存储的是运行环境必须的类信息,被装载进此区域的数据是不会被垃圾回收器回收掉的,关闭JVM 才会释放此区域所占用的内存。
Young Generation Space 新生区
新生区是类的诞生、成长、消亡的区域,一个类在这里产生,应用,最后被垃圾回收器收集,结束生命。新生区又分为两部分:伊甸区(Eden space )和幸存者区(Survivor pace ),所有的类都是在伊甸区被new 出来的。幸存区有两个: 0 区(Survivor 0 space )和1 区(Survivor 1 space )。当伊甸园的空间用完时,程序又需要创建对象,JVM 的垃圾回收器将对伊甸园区进行垃圾回收,将伊甸园区中的不再被其他对象所引用的对象进行销毁。然后将伊甸园中的剩余对象移动到幸存0 区。若幸存0 区也满了,再对该区进行垃圾回收,然后移动到1 区。那如果1 区也满了呢?再移动到养老区。
Tenure generation space 养老区
养老区用于保存从新生区筛选出来的JAVA 对象,一般池对象都在这个区域活跃。   三个区的示意图如下:



q  Method Area 方法区
方法区是被所有线程共享,该区域保存所有字段和方法字节码,以及一些特殊方法如构造函数,接口代码也在此定义。
q  PC Register 程序计数器
每个线程都有一个程序计数器,就是一个指针,指向方法区中的方法字节码,由执行引擎读取下一条指令。
q  Native Method Stack 本地方法栈
  • 大小: 13.4 KB
  • 大小: 19.8 KB
  • 大小: 34.9 KB
  • 大小: 50.5 KB
分享到:
评论

相关推荐

    jvm 详细介绍,了解jvm各个组成部分和功能

    为了提高内存分配效率,JVM 通常会采用一些优化策略,如分代收集技术。分代收集基于这样一个观察:大多数对象很快就会变得不可达,因此没有必要对整个堆进行频繁的垃圾回收。相反,JVM 将堆划分为不同的区域(如...

    JVM分享,包含JVM的优化目标、优化原则、JVM组成、内存区域划分、垃圾回收算法、垃圾回收器、FullGC触发时机等等.

    JVM的内容分享,包含JVM的优化目标、优化原则、JVM组成、内存区域划分、垃圾回收算法、垃圾回收器、FullGC触发时机、对象布局、元空间存储、GC调优

    JVM性能优化(PPT)

    理解预编译(-XX:+UseCountedLoopFeedback)和全速模式(-XX:+AggressiveOptimizations)等选项,可以进一步优化JVM的编译策略。 10. **类数据共享** 类数据共享(Class Data Sharing,CDS)可以减少启动时间和...

    深入JVM内核—原理、诊断与优化视频教程-3.常用JVM配置参数

    JVM主要由类加载子系统、运行时数据区、执行引擎、本地方法接口和本地方法库五个部分组成。其中,类加载子系统负责加载、验证、准备和初始化类文件;运行时数据区包括堆、栈、方法区、程序计数器和本地方法栈,它们...

    全面了解JVM组成底层工作原理以及数据结构

    了解JVM的组成及其工作原理对于提升Java应用程序的性能至关重要,它可以帮助开发者更好地诊断和解决内存泄漏、性能瓶颈等问题。通过对JVM底层工作原理的深入理解,开发者能够对Java程序的运行进行更精细的调优,比如...

    Jvm性能优化-JVM内存结构原理分析03

    了解Jvm内存结构、垃圾收集器、类加载器等知识点,可以帮助我们更好地优化Jvm的性能。 在Jvm中,垃圾收集器的选择对性能产生了很大的影响。不同的垃圾收集器适用于不同的场景,选择合适的垃圾收集器可以提高Jvm的...

    深入JVM内核—原理、诊断与优化视频教程-2.JVM运行机制

    Java虚拟机(JVM)是Java平台的核心组成部分,它负责执行字节码,为Java程序提供跨平台的运行环境。在深入理解JVM内核的运行机制时,我们需要关注以下几个关键点: 1. **类加载机制**:JVM通过类加载器将类文件加载...

    深入jvm 内核-原理,诊断于优化视频教程

    JVM主要由以下几个部分组成: - **类加载器子系统**:负责将.class文件加载到内存中。 - **运行时数据区**:包括方法区、堆、栈等区域,用于存储程序运行时的数据。 - **执行引擎**:解释或编译字节码为机器码进行...

    JVM参数优化及JVM解析.docx

    总之,理解和掌握JVM参数优化、运行时数据区的结构以及垃圾回收机制,是每个Java开发者提高应用性能、避免内存泄漏和优化系统资源利用率的关键。通过细心的调整和不断的实践,可以打造出更加高效稳定的Java应用程序...

    实战Java虚拟机 JVM故障诊断与性能优化 葛一鸣

    首先,JVM是Java语言的核心组成部分,它为Java应用程序提供了运行环境。JVM的主要任务是解析字节码,并将其转化为机器语言,使得Java程序能够在不同的操作系统上无缝运行,实现了“一次编写,到处运行”的目标。理解...

    实战JAVA虚拟机 JVM故障诊断与性能优化.rar

    《实战JAVA虚拟机 JVM故障诊断与性能优化》是一本深度探讨Java虚拟机(JVM)的专著,旨在帮助开发者解决实际工作中遇到的JVM相关问题,提升系统的性能表现。通过对JVM内部机制的深入理解,我们可以更有效地调试、...

    深入JVM内核—原理、诊断与优化

    GC(Garbage Collection)参数对于优化JVM的性能至关重要。常见的GC参数包括: - `-XX:NewRatio`:设定年轻代与老年代的比例。 - `-XX:SurvivorRatio`:设定Eden区与Survivor区的比例。 - `-XX:+UseParallelOldGC`:...

    实战JAVA虚拟机 JVM故障诊断与性能优化带源码

    首先,我们要明白JVM是Java语言的核心组成部分,它负责运行Java程序,提供跨平台的执行环境。JVM的主要组件包括类装载器、运行时数据区、执行引擎、本地方法接口和本地库。了解这些组件的工作机制是进行JVM故障诊断...

    实战Java虚拟机——JVM故障诊断与性能优化.pdf

    1. **JVM架构解析**:书中可能详细介绍了JVM的内存模型,包括堆内存、栈内存、方法区、本地方法栈以及程序计数器等组成部分,帮助读者理解JVM如何管理和使用内存。 2. **垃圾收集机制**:JVM的垃圾收集是其性能的...

    jvm视频及笔记

    Java虚拟机(JVM)是Java程序运行的核心组件,它负责解释和执行字节码,为开发者...理论学习后,实践操作是巩固知识的关键,尝试在实际项目中应用这些知识,解决性能问题,优化JVM配置,将使你对JVM的理解更加深入。

    jvm和gc详解及调优

    JVM是Java程序运行的基础,它是Java平台的核心组成部分,负责解释和执行Java字节码。书中可能涵盖了以下几个方面的内容: 1. **JVM架构**:JVM包括类装载器、运行时数据区、执行引擎、本地方法接口和本地方法库等...

    JVM优化与OOM分析PPT

    ### JVM优化与OOM分析 #### 一、JVM的重要性与作用 JVM(Java Virtual Machine)作为Java程序的运行环境,对于确保Java程序能够跨平台运行具有重要意义。它不仅提供了执行字节码的基础,还负责内存管理、垃圾回收...

    SAP JVM 8.1 64 bits

    总之,SAP JVM 8.1 64位是SAP系统的关键组成部分,它的优化和特性专门针对SAP环境进行了定制,以提供高效、稳定和安全的Java运行环境。通过理解和配置SAP JVM,可以更好地优化SAP应用程序的性能和稳定性。

    深入JVM内核 - 原理、诊断与优化

    在本课程中个,将详细介绍JVM的基本原理、组成以及工作方式,并配合实际案例,介绍相关的调优技巧。 课程大纲: 第一课 初识JVM JVM分类 Java语言规范 JVM规范 介绍JVM的基本知识和发展历史,并介绍了Java语言...

    JVM工作原理学习笔记

    这些工具能显示CPU使用率、内存分配、线程状态等关键信息,对于理解和优化JVM至关重要。 总的来说,理解JVM工作原理是每个Java开发者的必备技能。通过深入学习JVM,我们可以更好地设计和优化Java程序,提高系统性能...

Global site tag (gtag.js) - Google Analytics