`

JVM基础知识(原创)

 
阅读更多

JVM简介

JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。Java虚拟机包括一套字节码指令集、一组寄存器、一个栈、一个垃圾回收堆和一个存储方法域。 JVM屏蔽了与具体操作系统平台相关的信息,使Java程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。JVM在执行字节码时,实际上最终还是把字节码解释成具体平台上的机器指令执行。编译虚拟机的指令集与编译微处理器的指令集非常类似。

JDK内存

Java 的内存模型分为
Young(年轻代也叫new区)

Young分为 Eden 区和两个Survivor 区(from和to,这两个Survivor区大小严格一至),新的对象实例总是首先放在Eden 区,Survivor区作为Eden区和Tenure(终生代)的缓冲,可以向 Tenure(终生代)转移活动的对象实例。
Tenured(终身代,也叫old区)

Tenure中存放生命周期长久的实例对象,但并不是如它的名字那样是终生的,里面的对象照样会被回收掉。

Young和Tenure共同组成了堆内存,也就是heap内存或heap区。
Perm(永久代)
有些旧版本也叫作:New Old Perm 叫法不同,表达的意思却是基本相同。Perm则是非堆内存的组成部分。主要存放加载的Class类级对象如class本身,method,field等等。
Virtual区
在JVM启动时,就已经保留了固定的内存空间给Heap内存,这部分内存并不一定都会被JVM使用,但是可以确定的是这部分保留的内存不会被其他进程使用。这部分内存大小由 -Xmx 参数指定。
而另一部分内存在JVM启动时就分配给JVM,作为JVM的初始Heap内存使用。影响这个的参数是 -Xms ,如果 -Xms 指定的值比-Xmx 的小,那么两者的差值就是Virtual内存值。随着程序的运行,Eden区,Tenured区和Perm区会逐渐使用保留的Virtual空间。
如果没有具体指定,初始和最大堆内存将根据机器的内存计算得出。参数DefaultInitialRAMFraction 和 DefaultMaxRAMFraction 会影响最终的结果,如下表所示:
FormulaDefault
initial heap size memory / DefaultInitialRAMFraction memory / 64
maximum heap size MIN(memory / DefaultMaxRAMFraction, 1GB) MIN(memory / 4, 1GB)
可以看到堆内存默认值最大不会超过1G。
JVM会根据堆内存的使用情况自动决定何时扩张和缩减实际堆内存的大小,可以用VM参数 -XX:MinHeapFreeRatio= 和 -XX:MaxHeapFreeRatio= 使用堆内存空闲百分比来定义,一般在32位机器上的默认值如下:
ParameterDefault Value
MinHeapFreeRatio 40
MaxHeapFreeRatio 70
-Xms 3670k
-Xmx 64m
-Xms/-Xmx:
java heap并不是越大越好,对他的一般优化原则是够用的情况下,尽可能的小,因为太大的话会浪费内存,同时影响GC的效率。当空闲堆内存所占堆内存百分比低于40%,JVM就会试图扩张堆内存空间;当空闲堆内存所占堆内存百分比高于70%,JVM就会试图压缩堆内存空间。
ps:以上默认值在不同平台会有不同的值,如果是64位系统,这些值一般需要扩张30%,来容纳在64位系统下变大的对象。
GC

GC是Garbage Collection的缩写,即垃圾回收机制,在Java中开发人员无需使用指针来管理内存,GC是JVM对内存(实际上就是对象)进行管理的方式。
第一种为单线程GC,也是默认的GC。,该GC适用于单CPU机器。
第二种为Throughput GC,是多线程的GC,适用于多CPU,使用大量线程的程序。第二种GC与第一种GC相似,不同在于GC在收集Young区是多线程的,但在Old区和第一种一样,仍然采用单线程。-XX:+UseParallelGC参数启动该GC。
第三种为Concurrent Low Pause GC,类似于第一种,适用于多CPU,并要求缩短因GC造成程序停滞的时间。这种GC可以在Old区的回收同时,运行应用程序。-XX:+UseConcMarkSweepGC参数启动该GC。

第四种为Incremental Low Pause GC,适用于要求缩短因GC造成程序停滞的时间。这种GC可以在Young区回收的同时,回收一部分Old区对象。-Xincgc参数启动该GC。
不管采用什么算法,GC总是会导致应用暂停的,这个时间长短从毫秒到秒之间不等,因此会影响应用的相应时间,多长的停顿在接受范围内取决于应用的特征,可以通过设置GC停顿的时间来调整(注意只是期望的时间,而不是绝对)

相关调整的目标:
短生命周期的对象不要进入Old区
短生命周期的对象在minor GC的时候干掉
长生命周期的对象要放到Old区
长生命周期的对象可以被Full GC清理掉,但是Full GC要调整到尽量少发生

JVM中的ClassLoader

类加载器(class loader)用来加载java类到java虚拟机中。一般来说,java虚拟机使用java类的方式如下:Java源程序(.java文件)在经过java编译器编译之后就被转换成java字节代码(.class文件)。类加载器负责读取Java字节代码,并转换成java.lang.class类的一个实例。每个这样的实例用来表示一个java类。

Java程序是由许多独立的类文件组成的,每个文件对应于一个java类。此外,这些文件并非立即全部加载如内存,而是根据程序需要装入内存。ClassLoader便是JVM中将类装入内存的零件,用户可以定制自己的ClassLoader。JVM中缺省的ClassLoader可以完成将本地已文件系统装入类文件的任务。用户指定的ClassLoader可以拥有JVM缺省的ClassLoader所不具有的功能。例如:用户可以使用自己创建的ClassLoader从非本地硬盘或者从网络装入可执行内容。

java应用环境中不同的class分别由不同的ClassLoader负责加载。
一个jvm中默认的classloader有Bootstrap ClassLoader、Extension ClassLoader、App ClassLoader,分别各司其职:
Bootstrap ClassLoader:用来在JVM启动时加载核心类库,主要是 %JRE_HOME/lib/ 目录下的rt.jar、resources.jar、charsets.jar和class等
Extension ClassLoader:负责加载java扩展类,主要是%JRE_HOME/lib/ext目录下的jar和class
App ClassLoader:负责加载当前java应用classpath变量中的所有类。
其中Bootstrap ClassLoader是JVM级别的,由C++编写;Extension ClassLoader、App ClassLoader都是java类,都继承自URLClassLoader超类。
Bootstrap ClassLoader由JVM启动,然后初始化sun.misc.Launcher ,sun.misc.Launcher初始化Extension ClassLoader、App ClassLoader。
下图是ClassLoader的加载类流程图,以加载一个类的过程类示例说明整个ClassLoader的过程。


Java 类加载器层次结构
类加载器包含具有父类加载器和子类加载器的层次结构。父类加载器和子类加载器之间的关系类似于超类和子类之间的对象关系。引导类加载器是 Java 类加载器层次结构的根。Java 虚拟机 (JVM) 创建引导类加载器,它将加载 JVM 中包含的 Java Development Kit (JDK) 内部类和 java.* 包。(例如,引导类加载器加载 java.lang.String。)
扩展类加载器是引导类加载器的子类加载器。扩展类加载器加载 JDK 的扩展目录中包含的所有 JAR 文件。这是一种无需在类路径中添加条目即可扩展 JDK 的便捷方法。但扩展目录中的所有内容都必须是自包含的,且只能引用扩展目录中的类或 JDK 类。

系统类路径类加载器扩展 JDK扩展类加载器。系统类路径类加载器加载 JVM 类路径中的类。
加载类
类加载器在加载类时使用委托模型。类加载器实现首先检查其缓存,查看是否已经加载所请求的类。由于不重复从磁盘中加载类,而是使用该类在缓存内存中的副本,所以,这种类验证可以提高性能。如果在类缓存中找不到该类,则当前类加载器会要求其父类加载器提供该类。仅当父类加载器也无法加载该类时,该类加载器才会尝试加载该类。如果某个类既存在于父类加载器中,又存在于子类加载器中,则将加载父类加载器中的类。遵循这种委托模型可以避免同时加载多份相同的类。加载多份相同的类会引发 ClassCastException。
类加载器会先要求其父加载器加载类,然后再尝试自己加载该类。

参考至:《叱咤风云:WebLogic企业级运维实战》戴冠平著

             http://longdick.iteye.com/blog/442213

             http://songyishan.iteye.com/blog/1135183

             http://hi.baidu.com/love200456/blog/item/9d4d70fbdc38c970024f564f.html

             http://blog.sina.com.cn/s/blog_677e5328010109a3.html
本文原创,转载请注明出处、作者
如有错误,欢迎指正
邮箱:czmcj@163.com

0
3
分享到:
评论

相关推荐

    原创-JVM调优

    在JVM调优过程中,了解这些基础知识至关重要,它可以帮助开发者理解内存分配、垃圾回收、对象生命周期等关键概念,从而有效地调整JVM配置,提高应用程序的性能。例如,通过调整堆大小、设置新生代和老年代的比例、...

    程序员鱼皮的编程宝典。原创编程学习路线

    【描述】中提到,宝典主要关注Java和前端开发,这意味着它将深入讲解这两个领域的基础知识、进阶技巧和实际应用。Java作为后端开发的重要语言,其学习内容可能包括面向对象编程、JVM原理、多线程、Spring框架等;...

    JavaFamily:【Java面试+Java学习指南】 一份涵盖大部分Java程序员所需要掌握的核心知识

    Java基础知识 计算机操作系统与Linux 计算机网络 HTTP TCP/IP 7种常见的设计模式和使用场景 Java必会基础与新版本特性 集合框架 HashMap ConcurrentHashMap ArrayList Vector 深入浅出JVM JVM内存模型 性能调优、...

    java的虚拟机的英文规范

    Java虚拟机(JVM)是Java编程语言的核心组成部分,它为Java程序提供了运行环境。...这份规范详细而严谨,不仅涵盖了JVM的基本概念,还涉及了许多高级特性,是每一个Java开发者都应该掌握的基础知识。

    mavenjava源码-notebook:Java自学系列知识,包含Java基础、源码阅读、JVM、MySQL、Spring相关等

    Java自学系列知识 项目起源于自学Java过程中所做的300+系列笔记,点点滴滴的积累成就了本项目的体系结构... 随着我学习的不断深入,项目也在不断更新、完善中... 非常欢迎大家参与共建~~ 关于作者 就读于华南理工...

    JAVA架构师知识整理-副本.pdf

    除了Java相关的知识,架构师还应关注其他技术领域,例如数据库设计,这是构建应用的基础。架构师应掌握数据库的基本原理、SQL语言、索引优化、事务管理等。 架构师还需要具备良好的设计模式知识,理解各种设计模式...

    原创编程学习路线,包括全面的知识点、免费资源、面试题、学习建议、项目,适用于所有学习编程、求职的同学 已完成 Java、前端

    本资源包,"code-roadmap-main",提供了一条原创的编程学习路径,覆盖了Java和前端开发的主要知识点,旨在帮助你高效地掌握编程技能,并在求职过程中脱颖而出。 首先,我们来详细探讨Java编程的基础部分。Java是一...

    Win7下编译openjdk8源代码 完整版本 原创

    在介绍如何在Windows 7环境下编译OpenJDK 8源代码之前,有必要了解一些基础知识和前提条件。OpenJDK是Java平台的开源实现,其中包括JVM(Java虚拟机)和Java类库。OpenJDK的源代码使用C和C++编写,支持跨平台编译。...

    java工程师成神之路丨超全知识指南 基础篇.pdf

    本书作为《Java工程师成神之路》系列的第一部分,围绕Java基础知识展开,包括面向对象编程(OOP)的基本概念和核心原则,以及Java语言的基础特性。面向对象编程被分为面向对象和面向过程两种编程范式,本书在开始便...

    编译原理课件(原创)

    "编译原理"的课件,作为教师原创资料,通常会以易于理解的方式阐述这些概念,并可能包含实例、练习题和项目,帮助学生巩固所学知识。通过学习这门课,不仅可以掌握编译器设计的基础,还能提升对编程语言本质和程序...

    java8源码-JavaGuide:指南

    基础知识系统总结: 重要知识点详解: 容器 总结: 源码学习: 并发 面试题总结: 必备知识点: JVM I/O Java 8 优雅 Java 代码必备实践(Java编程规范) 网络 操作系统 Linux相关 数据结构与算法 数据结构 算法 ...

    Super-JavaGuide:基于JavaGuide和个人面试经验做出的总结

    大部分的题解来自网络,并非原创,有一部分标记了原始地址。 亲测熟练掌握本项目中提到的所有知识点,并且适当做挖掘,leetcode刷题400+就可以轻松的获得大厂offer! 推荐书籍 现代操作系统 图解HTTP 图解TCP/IP协议...

    java8源码-JavaOK:java面试知识总结

    基础知识系统总结: 重要知识点详解: (很重要的一个数据结构,用好枚举真的没有那么简单!) 其他: 容器 、 、 并发 面试题总结: 必备知识点: JVM 其他 I/O : Java 8 :、、 Java9~Java14 : Java编程规范: 、...

    chapter1.zip

    学习Java编程不仅要理解基础知识,还要通过实际项目练习巩固技能,了解最新的Java技术和框架,如Spring、MyBatis等,提升自己的开发能力。 总结,"chapter1.zip"可能包含了这些基础知识点的讲解和示例代码,对于...

    java8源码-javaknown:知乎

    基础知识系统总结: 重要知识点详解: (很重要的一个数据结构,用好枚举真的没有那么简单!) 其他: 容器 、 、 并发 面试题总结: 必备知识点: JVM 其他 I/O : Java 8 :、、 设计模式 : 网络 操作系统 操作...

    java8源码-JavaStudy:Java学习

    基础知识系统总结: 重要知识点详解: (很重要的一个数据结构,用好枚举真的没有那么简单!) 其他: 容器 、 、 并发 面试题总结: 必备知识点: JVM 其他 I/O : Java 8 :、、 Java9~Java14 : Java编程规范: 、...

    java8源码--:——

    基础知识系统总结: 重要知识点详解: (很重要的一个数据结构,用好枚举真的没有那么简单!) 其他: 容器 、 、 并发 面试题总结: 必备知识点: JVM 其他 I/O : Java 8 :、、 Java9~Java14 : Java编程规范: 、...

    java8源码-java-:Java-

    基础知识系统总结: 重要知识点详解: (很重要的一个数据结构,用好枚举真的没有那么简单!) 其他: 容器 、 、 并发 面试题总结: 必备知识点: JVM 其他 I/O : Java 8 :、、 Java9~Java14 : Java编程规范: 、...

    java8源码-Java-super-god:Java-超神

    基础知识系统总结: 重要知识点详解: (很重要的一个数据结构,用好枚举真的没有那么简单!) 其他: 容器 、 、 并发 面试题总结: 必备知识点: JVM 其他 I/O : Java 8 :、、 Java9~Java14 : Java编程规范: 、...

Global site tag (gtag.js) - Google Analytics