深入理解JVM虚拟机开篇:JVM介绍与知识脉络梳理

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/77992936   完整内容欢迎阅读我的博客专栏:深入理解JVM虚拟机   本文首发于我的个人公众号:程序员江湖 努力成为最有影响力的程序员自媒体,专注于面试,职场,个人提升三大主题。

微信公众号【Java技术江湖】一位阿里 Java 工程师的技术小站。作者黄小斜,专注 Java 相关技术:SSM、SpringBoot、MySQL、分布式、中间件、集群、Linux、网络、多线程,偶尔讲点Docker、ELK,同时也分享技术干货和学习经验,致力于Java全栈开发!(关注公众号后回复”Java“即可领取 Java基础、进阶、项目和架构师等免费学习资料,更有数据库、分布式、微服务等热门技术学习视频,内容丰富,兼顾原理和实践,另外也将赠送作者原创的Java学习指南、Java程序员面试指南等干货资源)


                     

 

转自:https://mp.weixin.qq.com/s/EjVfk1iOuQUjLfPxt_DJ7Q

 

是大名鼎鼎的Java 虚拟机,  据说这个星球上每天有900多万程序员和我打交道,这真是一个惊人的数字。 这900多万人中不少人对我的技术内幕非常感兴趣, 有事儿没事儿都要把我“大卸八块”, 深入了解一下。甚至还有人从我的出生地--源代码--开始看起,弄得人家连一点隐私都没有了。

 

当然也有很多人对我的运行机理爱理不理, 理由很简单: Java虚拟机相关的事情只有在面试时才会问道,背诵一下那些垃圾回收算法,应付过去就可以了!

 

真的是这样吗?  面试官为什么喜欢问JVM原理? 难道他们没什么可问的了? 或者是只是为了展示他们的卓尔不群? 高人一等?压你一头?

 

我想都不是,  请注意一下我的名字: Java虚拟机,  我是一个虚拟机啊!

 

虽然不是像VMWare, VirtualBox那样可以完全虚拟出一个包括内存,硬盘,CPU的硬件计算机出来, 我至少也是个Soft CPU啊, 有自己的指令集,有自己独有的可执行文件格式, 有自己独特的基于栈而不是寄存器的执行方式,还有那久经考验的垃圾回收机制......

 

作为一个口口声声说热爱编程,立志有写出伟大软件来改变世界的程序员, 少年, 难道你竟然对这么有趣的东西视而不见?

 

对软件技术的好奇心是你最终成为伟大程序员的第一驱动力, 如果你对技术不愿意深究, 不愿意了解背后的原理,如果你不愿意像一个调皮捣蛋的熊孩子那样把一个玩具变成零件,然后再组装起来(嗯, 实际上永远都组装不起来了) , 我真的怀疑你在这个行业能呆多久,走多远。

 

我刚才提到了有趣, 那真的有用吗?

 

表面上看是没有用处的,至少短期看来是没有用处的, 你写程序,运行程序,然后吃饭,睡觉。

 

管你什么基于栈的虚拟机,什么方法区,堆, 垃圾回收,  生活很美好,世界也很大, 我想去看看, 不要用这些烦心事来烦我。

如果你想一直生活在软件开发的表层, 那肯定是没有问题的, 如果你想像Neo那样,把这个世界看个清清楚楚,明明白白,真真切切, 就需要修炼一下内力, 做为Java 程序员, 理解Java虚拟机就是那个扎马步的基本功。

 

举个例子, 理解Class 文件格式, 就能理解ASM是怎么在运行时“艰难的”动态生成字节码的, 然后就会知道CGLib是怎么改善它, 让它容易使用的。  而CGLib可是Spring AOP赖以生存的一大基础啊。 这一路走来,是不是对AOP的理解更加透彻了?

 

你脑海中甚至能想象出来字节码怎么被动态的创建,被Classloader 加载, 形成新的Class,   然后对你的业务类进行拦截的过程。

看透世界的感觉不要太爽,    如果你非要说我会用Spring 的AOP就行了, 那我也没办法, 人各有志嘛。

 

扩展一下, 现在我的家中上入住了不少动态语言, Jython, JRuby , Clojure , Scala 等等, 他们可都需要动态的生成字节码来运行啊(码农翻身备注: Scala 也可以直接编译成class 文件), 你看看理解了Class 文件格式得有多大的好处。

 

还有啊, 理解了一些重要的字节码指令以后,你就会知道所谓的面向对象, 尤其是你写的那些个漂亮的OO代码, 在我这里已经“退化”成函数调用了, 不知道你会不会沮丧, 但是没有办法, 咱们计算机的本质就是这样,顺序,循环,分支, 函数调用。 作为补偿, 我会让你了解多态的秘密, 这可是很多面向对象语言的基础。

 

说到函数调用, 你写的Java程序在运行时会形成的栈帧, 这可真是一个超级重要的概念, 不仅在我这里有,物理CPU和内存在运行本地代码的时候也有,虽然我和他们的结构不同, 但都是为了完成一个目的:  表达一个函数在运行时的结构。

 

了解了这个家伙, 你就知道函数在机器级是怎么调用的, 参数是怎么传递的, 递归是怎么回事, 尾递归是怎么回事(我竟然不支持!) 。  也许你会跑去看看汇编, 去看看缓冲区溢出攻击, 各种知识点开始连接,形成一张大网,这种感觉是极爽的。

 

这样的例子我还可以举出很多,但是估计很多人已经不耐烦了,就此打住。

 

你们人类说计算机是门科学, 但是科学的成分在哪里呢?  在我看来更像一门工程或者技术,  核心的基础概念真的不多, 花点功夫把他们掌握了,受益终生。

 

前些天我偷偷地阅读了你们的小说《天龙八部》, 里边的扫地僧可真是厉害, 轻轻松松就把慕容博和萧远山两位绝顶高手制得服服帖帖,老老实实, 这说明的什么问题? 内功的修炼真是很重要啊。

 

jvm.png

前言

 JVM(Java Virtual Machine)Java 虚拟机是整个 java 平台的基石,是 java 系统实现硬件无关与操作系统无关的关键部分,是保障用户机器免于恶意代码损害的屏障。Java开发人员不需要了解JVM是如何工作的,**但是,**了解 JVM 有助于我们更好的开(通)发(过) java(公司) 程(面)序(试)。

写这篇文章的目的:

  • 总结所学的 JVM 知识
  • 帮助想了解 JVM 的朋友,知无不言,言无不尽

本篇文章将会介绍一下内容:

什么是 JVM

要想说明白什么 JVM 就不得不提另外两个概念,JRE 和 JDK,初学者总是把这几个概念搞混

java-tutorial.png

 

Jvm,Jre,Jdk 都是 java 语言的支柱,他们分工协作。但不同的是 Jdk 和 Jre 是真实存在的,而 Jvm 是一个抽象的概念,并不真实存在。

JDK
JDK(Java Development Kit) 是 Java 语言的软件开发工具包(SDK)。JDK 物理存在,是 programming tools、JRE 和 JVM 的一个集合

jdk.png


JRE
JRE(Java Runtime Environment)Java 运行时环境,JRE 物理存在,主要由Java API 和 JVM 组成,提供了用于执行 java 应用程序最低要求的环境。

jre.png

 

JVM
JVM(Java Virtual Machine) 是一种软件实现,执行像物理机程序的机器(即电脑)。
本来,Java被设计基于从物理机器分离实现WORA( 写一次,随处运行 )的虚拟机上运行,虽然这个目标已经几乎被遗忘。
JVM 并不是专为 Java 所实现的运行时,实际上只要有其他编程语言的编译器能生成正确 Java bytecode 文件,则这个语言也能实现在JVM上运行。
因此,JVM 通过执行 Java bytecode 可以使 java 代码在不改变的情况下运行在各种硬件之上。
jVM 有如下特点:

  • 基于堆栈的虚拟机 :最流行的计算机体系结构,如英特尔X86架构和ARM架构上运行基于寄存器 。 但是,JVM是基于栈的。
  • 符号引用 :除了基本类型以外的数据(类和接口)都是通过符号来引用,而不是通过显式地使用内存地址来引用。
  • 垃圾收集 :一个类的实例是由用户明确创建的代码和垃圾回收自动销毁。
    通过明确界定的基本数据类型的保证平台的独立性 :传统的语言,如C / C ++根据平台有不同的int型的大小。 JVM中明确规定了基本数据类型,以保持它的兼容性和保证平台的独立性。
  • 网络字节顺序 :Java class文件用网络字节码顺序来进行存储:为了保证和小端的Intel x86架构以及大端的RISC系列的架构保持无关性,JVM使用用于网络传输的网络字节顺序,也就是大端。

**Java bytecode **
为了实现WORA,JVM使用Java字节码,java(用户语言)和机器语言之间的中间语言。
该Java字节码是部署Java代码的最小单位。

JVM 用来做什么

基于安全方面考虑,JVM 要求在 class 文件中使用许多强制性的语法和机构化约束,但任意一门功能性语言都可以表示为一个能被 JVM 接受的有效的 class 文件。作为一个通用的、机器无关的执行平台,任何其他语言的实现者都可将 JVM 当作他的语言产品交付媒介。

JVM 中执行以下操作:

  • 加载代码
  • 验证代码
  • 执行代码
  • 提供运行环境

JVM 提供定义了:

  • 存储区
  • 类文件格式
  • 寄存器组
  • 垃圾回收堆
  • 致命错误报告等

JVM 生命周期

  • 启动:任何一个拥有main函数的class都可以作为JVM实例运行的起点
  • 运行:main函数为起点,程序中的其他线程均有它启动,包括daemon守护线程和non-daemon普通线程。daemon是JVM自己使用的线程比如GC线程,main方法的初始线程是non-daemon。
  • 消亡:所有线程终止时,JVM实例结束生命。

JVM 的整体架构

先看一下 java 代码执行过程

关于Jvm知识看这一篇就够了

转自: 纯洁的微笑 纯洁的微笑 3月11日

2016年左右的时候读了周志明深入理解Java虚拟机:JVM高级特性与最佳实践》,读完之后受益匪浅,让我对Java虚拟机有了一个完整的认识,这是Jvm书籍中最好的读物之一。

 

后来结合实际工作中遇到的问题,写了一系列关于Jvm的文章,其中开篇的几篇内容大部分参考于此书,后期加入自己一些实战的理解,转载了几篇高质量的文章,就形成了此系列读物。

 

 

 

在金三银四的跳槽季中,很多小伙伴们都已经蠢蠢欲动,将此系列文章整理出来,希望可以帮助到大家。

 

 

 

第一篇文章讲的是Java类的加载机制,也是我在博客园最收欢迎的Jvm文章,读完之后你会了解什么是类加载器、类加载机制、双亲委派模型等内容。

 

 

这篇文章描述了Java虚拟机的内存结构,内存每个区域作用,如何通过参数对各个区域进行控制。

 

 

讲述了Jvm垃圾回收的经典算法,以及各种垃圾回收机制,对象存活判断等。

 

这篇文章讲述了如何通过Jvm命令去调优,各Jvm命令使用方法。

 

 

这是非常有名的一张图,简单明了展示了GC日志的构成

文章介绍如何分析GC日志来诊断Java项目的运行状态,GC分析是生产调优的重要手段之一。

 

一名网友根据GC日志,进行Jvm调优的经典案例

 

介绍了Jvm调优各种工具的使用

 

如何你只是想通过面试,其实只要看一篇就够了,这篇文章将Jvm中的关键知识点进行了汇总。

 

翻译自国外的一篇Java GC文章,文章详细描述几种GC调优的方式,值得借鉴。

 

也是线上一场线上Jvm实战调优的经历,看着挺爽。

 

Java 8 Jvm内存变化

 

杜琪翻译的 Java 8 的新特性。

 

我们曾经线上出现事故后,定位分析的经历,结局出乎意料。

 

 

 

相关文章
|
24天前
|
监控 算法 Java
Java虚拟机(JVM)的垃圾回收机制深度解析####
本文深入探讨了Java虚拟机(JVM)的垃圾回收机制,旨在揭示其背后的工作原理与优化策略。我们将从垃圾回收的基本概念入手,逐步剖析标记-清除、复制算法、标记-整理等主流垃圾回收算法的原理与实现细节。通过对比不同算法的优缺点及适用场景,为开发者提供优化Java应用性能与内存管理的实践指南。 ####
|
16天前
|
监控 算法 Java
Java虚拟机(JVM)垃圾回收机制深度剖析与优化策略####
本文作为一篇技术性文章,深入探讨了Java虚拟机(JVM)中垃圾回收的工作原理,详细分析了标记-清除、复制算法、标记-压缩及分代收集等主流垃圾回收算法的特点和适用场景。通过实际案例,展示了不同GC(Garbage Collector)算法在应用中的表现差异,并针对大型应用提出了一系列优化策略,包括选择合适的GC算法、调整堆内存大小、并行与并发GC调优等,旨在帮助开发者更好地理解和优化Java应用的性能。 ####
25 0
|
13天前
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
15天前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
19天前
|
机器学习/深度学习 监控 算法
Java虚拟机(JVM)的垃圾回收机制深度剖析####
本文深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法、性能调优策略及未来趋势。通过实例解析,为开发者提供优化Java应用性能的思路与方法。 ####
31 1
|
29天前
|
监控 Java 开发者
Java虚拟机(JVM)深度优化指南####
本文深入探讨了Java虚拟机(JVM)的工作原理及其性能优化策略,旨在帮助开发者通过理解JVM的内部机制来提升Java应用的运行效率。不同于传统的技术教程,本文采用案例分析与实战技巧相结合的方式,为读者揭示JVM调优的艺术。 ####
55 8
|
25天前
|
监控 算法 Java
深入理解Java虚拟机(JVM)的垃圾回收机制
【10月更文挑战第21天】 本文将带你深入了解Java虚拟机(JVM)的垃圾回收机制,包括它的工作原理、常见的垃圾收集算法以及如何优化JVM垃圾回收性能。通过本文,你将对JVM垃圾回收有一个全新的认识,并学会如何在实际开发中进行有效的调优。
41 0
|
前端开发 Java 应用服务中间件
【Java虚拟机】JVM类加载机制和双亲委派模型
【Java虚拟机】JVM类加载机制和双亲委派模型
【Java虚拟机】JVM类加载机制和双亲委派模型
|
安全 Java 应用服务中间件
深入理解JVM虚拟机6:深入理解JVM类加载机制
深入理解JVM类加载机制 简述:虚拟机把描述类的数据从class文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就是虚拟机的类加载机制。
|
29天前
|
Ubuntu 网络安全 虚拟化
VMware虚拟机ping不通原因排查及分析
下面以 VMware 虚拟机为例进行介绍。
420 3