`

JVM-工作原理

    博客分类:
  • java
 
阅读更多
一、         JVM的生命周期

1.       JVM实例对应了一个独立运行的java程序它是进程级别

a)     启动。启动一个Java程序时,一个JVM实例就产生了,任何一个拥有public static void main(String[] args)函数的class都可以作为JVM实例运行的起点

b)     运行。main()作为该程序初始线程的起点,任何其他线程均由该线程启动。JVM内部有两种线程:守护线程和非守护线程,main()属于非守护线程,守护线程通常由JVM自己使用,java程序也可以标明自己创建的线程是守护线程

c)     消亡。当程序中的所有非守护线程都终止时,JVM才退出;若安全管理器允许,程序也可以使用Runtime类或者System.exit()来退出

2.       JVM执行引擎实例则对应了属于用户运行程序的线程它是线程级别的



二、         JVM的体系结构




1.       类装载器(ClassLoader)(用来装载.class文件)

2.       执行引擎(执行字节码,或者执行本地方法)

3.       运行时数据区(方法区、堆、java栈、PC寄存器、本地方法栈)



三、         JVM类加载器

JVM整个类加载过程的步骤:

1.       装载

装载过程负责找到二进制字节码并加载至JVM中,JVM通过类名、类所在的包名通过ClassLoader来完成类的加载,同样,也采用以上三个元素来标识一个被加载了的类:类名+

包名+ClassLoader实例ID。

2.       链接

链接过程负责对二进制字节码的格式进行校验、初始化装载类中的静态变量以及解析类中调用的接口、类。

完成校验后,JVM初始化类中的静态变量,并将其值赋为默认值。

最后对类中的所有属性、方法进行验证,以确保其需要调用的属性、方法存在,以及具备应的权限(例如public、private域权限等),会造成NoSuchMethodError、NoSuchFieldError等错误信息。

3.       初始化

初始化过程即为执行类中的静态初始化代码、构造器代码以及静态属性的初始化,在四种情况下初始化过程会被触发执行:

调用了new;

反射调用了类中的方法;

子类调用了初始化;

JVM启动过程中指定的初始化类。



JVM类加载顺序:

JVM两种类装载器包括:启动类装载器和用户自定义类装载器。

启动类装载器是JVM实现的一部分;

用户自定义类装载器则是Java程序的一部分,必须是ClassLoader类的子类。

JVM装载顺序:

                Jvm启动时,由Bootstrap向User-Defined方向加载类;

                应用进行ClassLoader时,由User-Defined向Bootstrap方向查找并加载类;

1.       Bootstrap ClassLoader

这是JVM的根ClassLoader,它是用C++实现的,JVM启动时初始化此ClassLoader,并由此ClassLoader完成$JAVA_HOME中jre/lib/rt.jar(Sun JDK的实现)中所有class文件的加载,这个jar中包含了java规范定义的所有接口以及实现。

2.       Extension ClassLoader

JVM用此classloader来加载扩展功能的一些jar包。

3.       System ClassLoader

JVM用此classloader来加载启动参数中指定的Classpath中的jar包以及目录,在Sun JDK中ClassLoader对应的类名为AppClassLoader。

4.       User-Defined ClassLoader

User-DefinedClassLoader是Java开发人员继承ClassLoader抽象类自行实现的ClassLoader,基于自定义的ClassLoader可用于加载非Classpath中的jar以及目录。



ClassLoader抽象类的几个关键方法:

(1)       loadClass

此方法负责加载指定名字的类,ClassLoader的实现方法为先从已经加载的类中寻找,如没有则继续从parent ClassLoader中寻找,如仍然没找到,则从System ClassLoader中寻找,最后再调用findClass方法来寻找,如要改变类的加载顺序,则可覆盖此方法

(2)       findLoadedClass

此方法负责从当前ClassLoader实例对象的缓存中寻找已加载的类,调用的为native的方法。

(3)       findClass

此方法直接抛出ClassNotFoundException,因此需要通过覆盖loadClass或此方法来以自定义的方式加载相应的类。

(4)       findSystemClass

此方法负责从System ClassLoader中寻找类,如未找到,则继续从Bootstrap ClassLoader中寻找,如仍然为找到,则返回null。

(5)       defineClass

此方法负责将二进制的字节码转换为Class对象

(6)       resolveClass

此方法负责完成Class对象的链接,如已链接过,则会直接返回。



四、         JVM执行引擎

在执行方法时JVM提供了四种指令来执行:

(1)invokestatic:调用类的static方法

(2)invokevirtual:调用对象实例的方法

(3)invokeinterface:将属性定义为接口来进行调用

(4)invokespecial:JVM对于初始化对象(Java构造器的方法为:<init>)以及调用对象实例中的私有方法时。



主要的执行技术有:

解释,即时编译,自适应优化、芯片级直接执行

(1)解释属于第一代JVM,

(2)即时编译JIT属于第二代JVM,

(3)自适应优化(目前Sun的HotspotJVM采用这种技术)则吸取第一代JVM和第二代

JVM的经验,采用两者结合的方式

开始对所有的代码都采取解释执行的方式,并监视代码执行情况,然后对那些经常调用的方法启动一个后台线程,将其编译为本地代码,并进行优化。若方法不再频繁使用,则取消编译过的代码,仍对其进行解释执行。



五、         JVM运行时数据区

第一块:PC寄存器

PC寄存器是用于存储每个线程下一步将执行的JVM指令,如该方法为native的,则PC寄存器中不存储任何信息。

第二块:JVM栈

JVM栈是线程私有的,每个线程创建的同时都会创建JVM栈,JVM栈中存放的为当前线程中局部基本类型的变量(java中定义的八种基本类型:boolean、char、byte、short、int、long、float、double)、部分的返回结果以及Stack Frame,非基本类型的对象在JVM栈上仅存放一个指向堆上的地址

第三块:堆(Heap)

它是JVM用来存储对象实例以及数组值的区域,可以认为Java中所有通过new创建的对象的内存都在此分配,Heap中的对象的内存需要等待GC进行回收。

(1)       堆是JVM中所有线程共享的,因此在其上进行对象内存的分配均需要进行加锁,这也导致了new对象的开销是比较大的

(2)       Sun Hotspot JVM为了提升对象内存分配的效率,对于所创建的线程都会分配一块独立的空间TLAB(Thread Local Allocation Buffer),其大小由JVM根据运行的情况计算而得,在TLAB上分配对象时不需要加锁,因此JVM在给线程的对象分配内存时会尽量的在TLAB上分配,在这种情况下JVM中分配对象内存的性能和C基本是一样高效的,但如果对象过大的话则仍然是直接使用堆空间分配

(3)       TLAB仅作用于新生代的Eden Space,因此在编写Java程序时,通常多个小的对象比大的对象分配起来更加高效。

第四块:方法区域(Method Area)

(1)在Sun JDK中这块区域对应的为PermanetGeneration,又称为持久代。

(2)方法区域存放了所加载的类的信息(名称、修饰符等)、类中的静态变量、类中定义为final类型的常量、类中的Field信息、类中的方法信息,当开发人员在程序中通过Class

对象中的getName、isInterface等方法来获取信息时,这些数据都来源于方法区域,同时方法区域也是全局共享的,在一定的条件下它也会被GC,当方法区域需要使用的内存超过其允许的大小时,会抛出OutOfMemory的错误信息。

第五块:运行时常量池(Runtime Constant Pool)

存放的为类中的固定的常量信息、方法和Field的引用信息等,其空间从方法区域中分配。

第六块:本地方法堆栈(Native Method Stacks)

JVM采用本地方法堆栈来支持native方法的执行,此区域用于存储每个native方法调用的状态。



六、         JVM垃圾回收

GC的基本原理:将内存中不再被使用的对象进行回收,GC中用于回收的方法称为收集器,由于GC需要消耗一些资源和时间,Java在对对象的生命周期特征进行分析后,按照新生代、旧生代的方式来对对象进行收集,以尽可能的缩短GC对应用造成的暂停

(1)对新生代的对象的收集称为minor GC;

(2)对旧生代的对象的收集称为Full GC;

(3)程序中主动调用System.gc()强制执行的GC为Full GC。

不同的对象引用类型, GC会采用不同的方法进行回收,JVM对象的引用分为了四种类型:

(1)强引用:默认情况下,对象采用的均为强引用(这个对象的实例没有其他对象引用,GC时才会被回收)

(2)软引用:软引用是Java中提供的一种比较适合于缓存场景的应用(只有在内存不够用的情况下才会被GC)

(3)弱引用:在GC时一定会被GC回收

(4)虚引用:由于虚引用只是用来得知对象是否被GC

转载自:http://www.open-open.com/lib/view/open1408453806147.html
分享到:
评论

相关推荐

    weilei-JVM-ppt.rar

    "JAVA进阶高级jav"进一步指出这份资料主要面向已经有一定基础的Java开发者,旨在帮助他们深入理解JVM的工作原理,提升到更高级的Java开发水平。 【压缩包子文件的文件名称列表】"尚宋-硅红-谷康-JVM-ppt"可能是作者...

    jvm-demo.zip

    通过对"jvm-demo.zip"的深入研究,我们可以全面掌握JVM的工作原理,提升我们的Java开发和优化技能,更好地驾驭这个强大的运行环境。在实践中不断探索和学习,才能真正成为一名精通JVM的专业人士。

    jvm-profiler,jvm分析器向kafka、控制台输出或自定义报告器发送度量.zip

    "jvm-profiler"的实现原理是通过Java代理技术,即在目标应用程序启动时插入一个代理,这个代理会在JVM的生命周期内持续收集各种指标。代理可以捕获到JVM级别的信息,如垃圾回收的频率和时间,线程的状态,以及方法...

    jvm调优测试仓库-jvm-monitor.zip

    《深入解析JVM调优与监控》 在Java开发领域,JVM(Java ...通过深入理解JVM的工作原理,结合有效的监控手段,我们可以不断提升Java应用的性能和稳定性。在实践中,我们需要持续学习和探索,以应对各种复杂的性能挑战。

    深入jvm内核-原理、诊断与优化教学视频

    1、java虚拟机的基本介绍。 2、字节码的执行 3、常用的jvm参数配置 4、算法和种类 5、gc参数配置 6、类加载器 7、性能监控工具 8、jvm堆栈分析

    gp-jvm-visualvm

    首先,我们需要理解JVM的工作原理。JVM是一个抽象的计算机,它实现了Java语言规范定义的虚拟计算机。它的主要任务是运行Java应用程序,通过解释和编译字节码来实现这一点。在运行过程中,JVM会管理内存,包括堆...

    jvm-sandbox demo

    JVM沙箱原理:** JVM沙箱基于Java的类加载机制,通过自定义类加载器来实现对代码的动态加载和控制。它拦截并控制类的加载过程,允许在运行时动态地修改类的行为,同时对代码执行进行细粒度的权限控制。 **2. 安装...

    mini-jvm in rust实现jvm,jvm-rs-main.zip

    然而,JVM的内部工作原理对于许多开发者来说仍然是一个神秘的概念。本文将探讨一个特殊的项目——"mini-jvm in rust",该项目是用Rust语言实现的一个小型Java虚拟机,旨在帮助开发者理解JVM的核心机制。项目名为"jvm...

    JVM-HotSpot-原理

    • HotSpot • ClassFile • ClassLoader • 内存模型、锁、同步 • JVM内存管理和垃圾收集 Java发展历程 JVM列表 OpenJDK 编译执行过程 解析执行和JIT编译

    深入JVM---JVM命令---invokespecial

    《深入JVM---JVM命令---...理解`invokespecial`的工作原理有助于我们更深入地理解JVM的运行机制,进而优化Java程序的性能和设计。在实际编程中,合理运用这些知识能帮助我们编写出更加高效、稳定和安全的代码。

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

    本教程旨在帮助开发者深入了解JVM的工作原理及其内部机制,掌握JVM调优的方法和技术。通过学习本教程,开发者不仅能够提高自己的技术水平,还能更好地应对实际工作中遇到的问题。希望各位能够在学习过程中不断探索、...

    JVM-整体结构原理深度解析

    ### JVM-整体结构原理深度解析 #### 一、JVM简介及跨平台性 ##### 1.1 JVM定义 JVM(Java Virtual Machine),即Java虚拟机,是一种用于计算设备的规范,它模拟了一个计算机环境,允许Java程序在这个虚拟环境中...

    jvm-demo1.zip

    首先,我们要了解JVM的基本结构和工作原理。JVM是Java程序的执行引擎,它负责将字节码转换为机器语言,从而在不同平台上运行。JVM的内存模型包括堆、栈、方法区、本地方法栈和程序计数器等几个部分,每个部分都有其...

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

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

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

    Java虚拟机(JVM)是Java程序运行...通过深入理解JVM的工作原理,并结合实际应用进行调优,开发者可以提升Java应用的稳定性和性能。这份"jvm-training"资料包将帮助你系统学习这些关键知识点,成为Java性能优化的专家。

    日常笔记-JVM内核-原理、诊断与优化

    日常笔记-JVM内核-原理、诊断与优化

    JVM工作原理学习笔记

    本文将深入探讨JVM的工作原理,包括内存管理、类加载机制、垃圾回收以及性能优化等方面。 首先,我们来理解JVM的内存结构。在JVM中,内存被分为堆内存和栈内存两大部分。堆内存主要用于存储对象实例,而栈内存则...

    JVM调优的测试项目-JVM-subject.zip

    了解不同GC算法(如Serial、Parallel、CMS、G1等)的工作原理和适用场景,可以帮助我们优化GC性能,减少不必要的停顿时间。 3. **JVM参数设置**:通过调整-Xms、-Xmx设定堆内存大小,-XX:NewRatio设定新生代与老...

    JVM--字节码和类的加载篇1

    Java虚拟机(JVM)是Java程序的核心组成部分,它负责执行字节码,这是Java程序在编译后的二进制...理解这些知识点对于深入学习JVM的工作原理,优化Java代码性能,以及解决部署环境与开发环境之间的兼容性问题至关重要。

    揭秘Java虚拟机-JVM设计原理与实现

    《揭秘Java虚拟机-JVM设计原理与实现》这本书深入探讨了Java虚拟机(JVM)的工作原理及其在Java编程中的核心地位。Java虚拟机是Java平台的核心组成部分,它负责执行字节码,为开发者提供了跨平台的运行环境。以下是...

Global site tag (gtag.js) - Google Analytics