`

[转]整理关于JVM方面的知识点

 
阅读更多

转自:http://furturestrategist.iteye.com/blog/1415852

 

 

 

本周开发任务基本完成,整理下关于JVM方面的知识点

照顾下新来JE的同学,先发个链接到两位大牛的主页 
              http://rednaxelafx.iteye.com/ 
              http://icyfenix.iteye.com/ 

 

      目录

  •     1)概述
  •      
  •     2)编译
  •      
  •     3)Class文件结构
  •     
  •     4)通过ClassLoader加载Class
  •      
  •     5)类执行机制
  •      
  •     6)运行时数据区
  •      
  •     7)垃圾回收相关
  •       
  •     8)多线程
  •      
  •     9)故障检测工具及命令
  •      
  •     10)其他
  •  

       1) 概述

            1.1) 引用一张官网的图阐明JDK、JRE、JVM、JIT的关系(如下图所示),我们可以看见JDK>JRE>JVM>JIT,JIT分为client模式和server模式两种,代码如果执行频率过高就会被JIT编译器转换成二进制执行,JVM是JAVA跨平台的依赖,JVM在不同平台中开辟一块属于自己的内存,独立运行自己的任务,JRE除了包含JVM以外,还包括SUN开发出来的接口与实现方便程序猿们利用JAVA语言开发,除了需要了解开放的部分Code以外,我们通常需要熟悉核心的API来满足我们开发的需求,JDK除了包含JRE还包括一些自带的命令,如将JAVA代码转换成class文件的javac命令、执行class文件的java命令、将注解变成API的javadoc命令、反编译javap、将java文件转换成jar包的jar命令,以及一些故障检测工具和命令等等.....     



 

 
                   1.2)  虚拟机的规范与实现,JAVA语言提供了虚拟机的规范,各大厂商提供了JVM的实现,目前我们使用最多的是原Sun的Hotspot虚拟机,提供JDK7的最新JVM规范http://docs.oracle.com/javase/specs/jvms/se7/jvms7.pdf




                   1.3) JVM的标准结构,宏观认识下JVM的组成架构,如图




                     1.4) 一些疑问...

                           1.4.1 ) JAVA API已经封装的很好了,而且对象也不需要我们手动回收,为什么需要了解JVM方面知识?

                           个人看法:了解、熟悉JVM可以帮助我们在编码过程中注意内存分配、提高代码执行性能、保证并发量很高的时线程安全、合理的解决复杂的需求、调优、搭建应用服务器架构、服务器宕机、内存溢出时候可以快速让我们定位到问题并解决。

                                        1.4.2 ) 如何看待并学习JVM?

                            个人看法:和学习其他知识相同,掌握如何使用基础上要了解其原理,如果把JDK的API看成提供给用户的使用手册,那么JVM相关规范就是开发人员的文档,JVM方面知识有些杂、并且比较深,国内在R和F的带动下已经有很多同学意识到这方面的重要性,个人建议学习这方面知识点可以理论与实际相结合,循序渐进,当然我自己也是个才入门的新手 (*^__^*)  

        2)  编译

             JDK的编译实现是用JAVAC来实现的,如下图所示,编译过程是编译器如何优化是编译器和JAVAC考虑的问题,因此文档和学习资料也比较少。



 

           3)  Class文件结构

                 3.1)  Class文件结构包含什么?

                        1)  Class文件格式版本号

                        2)  类/继承癿超类/ 实现癿接口癿声明信息

                        3)  域和方法声明的信息

                        4)  常量池

                        5)  字节码

                        6)  异常处理表

                        7)  操作数栈与局部变量区的大小

                        8)  StackMapTable

                        9)  .....

                       3.2)  虚拟机规范支持的数据类型。如下图所示

 

 

                     3.3)  Class文件指令,如下图所示

 



对应的JAVA代码为


 

 

 

 

 

 

 

 test方法中对应指令解释

  0:iconst_0                //定义常量0,放入操作数栈 

  1:istore_1                //弹出栈顶放入局部变量区

  2:iload_1                 //将变量存入i中

  3:bipush 100           //将100放入操作数栈

  5:if_icmpge              //i与100比较

  8:getstatic               //获取静态方法

  11:i_load1               //加载变量i

  12:invokevirtual      //调用PrintStream对象的print方法输出i

  15:iinc  1,1              //将变量i自加

  18:goto 2               //跳转到第二行

   return                    //返回

 

                     3.4) 虚拟机字节码调用方法相关指令集

                   invokevirtual       调用普通方法

                   invokestatic        调用静态方法

                   invokespecial     调用构造方法

                   invokeinterface   调用接口的方法

                        invokedynamic(JDK7) 动态字节码指令 http://icyfenix.iteye.com/blog/1392441

       

    4) 通过ClassLoader加载Class

              4.1) ClassLoader的层次关系

 



 
启动:
jdk/lib目录
Xbootclasspath指定jar包
 系统:
classpath所指目录与jar包
Djava.class.path所指目录与jar包
 
 自定义:运行期ClassLoader子类动态加载class文件
 
 
扩展:jdk/lib/ext目录Djava.ext.dirs指定jar包


                  4.2) Class的链接

                           4.2.1) 校验Class,可能会抛出的异常

                                  1) 当不符合JVM的Class规范的时候会抛出来VeriftError异常

                                  2) 当引用类不存在的时候会出现NoClassDefFoundError异常

                                  3) 变量不存在的时候会出现NoSuchFiledError异常

                                  4) 方法不存在会出现NoSuchMethod异常

                    4.2.2) 在连接过程中会初始化静态变量

             4.3) Class的初始化时间

                    1) JVM指定初始化内容

                    2) new出来的对象

                    3) 反射

                    4)子类初始化

                    5) 调用对象的静态变量或者静态方法

                    6) .....

             4.4) 初始化内容

                     1) 静态代码块

                     2) 构造方法

                     3) 类变量

        5) 类执行的机制

           5.1) JVM有两种执行方式,分别为解释执行和编译执行,解释执行直接执行字节码文件,编译执行先将字节码转成机器码,然后再执行,编译执行的效率要比解释执行的高,通常当代码被编译的“热度”到一定程度后会变成编译执行。如下图所示

 

 
               5.2) 编译执行依赖于JIT编译器,JAVA为我们提供了Client模式和Server模式,Client模式做了少量的优化(方法内联、去虚拟化、冗余消除),Server的模式做了大量的优化(逃逸分析、标量替换、栈上分配、同步消除)

       6) 运行时数据区

           6.1)JAVA运行期内存如图所示

            

 

分享到:
评论

相关推荐

    JVM与性能优化知识点整理.pdf

    JVM的性能优化是提升Java应用效率的关键环节,涉及到内存管理、垃圾收集、线程调度等多个方面。** 一、JVM内存结构 1. **堆内存**:Java对象的主要存储区域,分为新生代和老年代,新生代又细分为Eden区和两个...

    JVM与性能优化知识点整理.zip

    以下是对JVM与性能优化相关知识点的详细阐述: 1. **JVM内存模型** - **堆内存**:这是JVM中最大的一块内存,用于存储对象实例。堆被分为新生代和老年代,新生代又细分为Eden和两个Survivor空间。 - **栈内存**:...

    jvm的基础知识总结

    总结以上知识点,JVM作为Java程序的运行环境,拥有复杂的内存管理机制和高效的垃圾回收策略。理解JVM的内存模型、垃圾回收算法、类加载机制以及线程模型对编写高效稳定Java应用至关重要。同时,直接内存的使用也是...

    JAVA面试核心知识点整理(283页).pdf

    本文档旨在为Java开发者提供一个 hệ thống的面试知识点整理,涵盖了Java的核心概念、JVM的工作原理、Java编程语言的基本语法和高级特性等多方面的知识点。下面是对该文档的详细解读。 JVM知识点 JVM(Java ...

    jvm知识点总览完整版

    ### JVM知识点总览 #### JVM概述与重要性 在IT领域,尤其是对于Java开发者而言,JVM(Java Virtual Machine,Java虚拟机)的重要性不言而喻。正如武术中所说的“内外兼修”,对于初级程序员来说,掌握框架和API的...

    JAVA核心知识点整理学习.pdf

    Java是一种广泛使用的高级编程语言,它的核心知识点涵盖了Java编程语言的基础知识、Java虚拟机(JVM)的工作机制、Java的内存管理机制等方面。下面是对Java核心知识点的整理和学习。 目录 Java的目录结构是Java...

    JVM与性能优化--知识点整理.pdf

    JVM性能优化主要涉及内存管理(如堆大小调整、垃圾收集策略选择)、类加载优化、线程调度、代码编译(JIT编译)等方面。理解这些基本概念,结合监控工具(如VisualVM、JProfiler)分析运行时数据,可以帮助我们识别...

    JAVA核心知识点整理

    综上所述,"JAVA核心知识点整理"涵盖了Java开发的各个方面,从基础到高级,从理论到实践,是成为一名专业Java开发者所必须掌握的内容。通过深入学习并实践这些知识点,将有助于提升个人技能,应对各种开发挑战。

    JAVA核心知识点整理.pdf

    Java的核心知识点包括多个方面,本文档将对其重要知识点进行整理,确保覆盖从基础到高级的多个维度。 首先,关于JVM(Java虚拟机),它是Java平台的基础,负责运行Java字节码。JVM内存区域分为多个部分,每个部分都...

    java核心知识点整理.pdf

    "Java核心知识点整理" Java是一种流行的高级...Java核心知识点整理是一个复杂的主题,涵盖了Java语言的基础概念、Java虚拟机、垃圾回收机制、线程、内存区域等方面。理解这些知识点对于Java开发者来说是非常重要的。

    jvm基础知识与调优-jvm-training.zip

    Java虚拟机(JVM)是Java程序运行的基础,它提供了执行字节码的平台无关环境。JVM基础知识与调优是每一个Java开发者都需要掌握的...这份"jvm-training"资料包将帮助你系统学习这些关键知识点,成为Java性能优化的专家。

    JVM必知必会

    ### JVM必知必会知识点梳理 #### 1. JVM的定义与层次 Java虚拟机(JVM)具有多重含义: - **一套规范**:即Java虚拟机规范,定义了Java虚拟机应该具有的行为。 - **一种实现**:例如HotSpot、J9、JRockit,它们都是...

    Java核心知识点整理.pdf

    Java核心知识点整理.pdf的目录是Java学习的roadmap,涵盖了Java语言的各个方面,包括Java虚拟机(JVM)、Java语言基础、Java高级特性、Java框架和工具等。 JVM(Java Virtual Machine) JVM是Java语言的核心组件,...

    jvm详解资料

    ### JVM详解资料核心知识点 #### Java相关 - **Java定义**:Java是一种广泛使用的面向对象的编程语言,设计初衷是为了实现“一次编写,到处运行”的跨平台能力,这得益于其运行环境——Java虚拟机(JVM)的存在。 ...

    深入理解JVM

    根据提供的信息,我们可以深入探讨与“深入理解JVM”这一主题相关的知识点。虽然描述部分的信息重复,但从标题可以看出,文章的主要目的是围绕Java虚拟机(JVM)进行深入剖析。接下来,我们将详细阐述JVM的基本概念、...

    JAVA核心知识点整理.docx

    本文将从 JVM、线程、JVM 内存区域、垃圾回收、Java 语法等方面ystematically 整理 JAVA 核心知识点,旨在帮助读者更好地理解和掌握 JAVA 语言。 一、JVM(Java Virtual Machine) JVM 是 JAVA 语言的核心组件之一...

    JVM面试思考准备.pdf

    本文档是一份专门为JVM面试准备的材料,涵盖了JVM技术面试中经常被问到的知识点,针对的是使用Java开发语言的程序员。内容包含了JVM的知识体系、内存结构、类的加载机制、垃圾回收(GC)算法及分析命令调优等方面的...

Global site tag (gtag.js) - Google Analytics