深入理解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程序员面试指南等干货资源)


                     9eedaaa588bef997bef63a7160fa349134bdb78c

 

转自: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 的新特性。

 

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

 

 

 

相关文章
|
2月前
|
Java Docker 索引
记录一次索引未建立、继而引发一系列的问题、包含索引创建失败、虚拟机中JVM虚拟机内存满的情况
这篇文章记录了作者在分布式微服务项目中遇到的一系列问题,起因是商品服务检索接口测试失败,原因是Elasticsearch索引未找到。文章详细描述了解决过程中遇到的几个关键问题:分词器的安装、Elasticsearch内存溢出的处理,以及最终成功创建`gulimall_product`索引的步骤。作者还分享了使用Postman测试接口的经历,并强调了问题解决过程中遇到的挑战和所花费的时间。
|
2月前
|
存储 安全 Java
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程,JDK、JRE、JVM关系;程序计数器,堆,虚拟机栈,堆栈的区别是什么,方法区,直接内存
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程是什么,JDK、JRE、JVM的联系与区别;什么是程序计数器,堆,虚拟机栈,栈内存溢出,堆栈的区别是什么,方法区,直接内存
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程,JDK、JRE、JVM关系;程序计数器,堆,虚拟机栈,堆栈的区别是什么,方法区,直接内存
|
3月前
|
Arthas 监控 算法
JVM成神路终章:深入死磕Java虚拟机序列总纲
JVM成神路终章:深入死磕Java虚拟机序列总纲
|
3月前
|
监控 Oracle Java
(一)JVM成神路之初识虚拟机 - 探寻Java虚拟机的前世今生之秘
JVM(Java Virtual Machine)Java虚拟机的概念大家都不陌生,Java之所以可以做到“一次编译,到处运行”的跨平台性,其根本原因就在于JVM。JVM是建立在操作系统(OS)之上的,Java虚拟机屏蔽了开发人员与操作系统的直接接触,我们在通过Java编写程序时,只需要负责编写Java代码即可,关于具体的执行则会由JVM加载字节码后翻译成机械指令交给OS执行。
|
2月前
|
监控 算法 Java
深入理解Java虚拟机:JVM调优与性能提升
本文旨在为Java开发者提供一条清晰的路径,以深入掌握Java虚拟机(JVM)的内部机制和性能调优技巧。通过具体案例分析,我们将探讨如何识别性能瓶颈、选择合适的工具进行监控与调试,以及实施有效的优化策略,最终达到提高应用程序性能的目的。文章不仅关注理论,更注重实践应用,帮助读者在面对复杂的Java应用时能够游刃有余。
57 0
|
3月前
|
存储 Java 对象存储
Java虚拟机(JVM)中的栈(Stack)和堆(Heap)
在Java虚拟机(JVM)中,栈(Stack)和堆(Heap)是存储数据的两个关键区域。它们在内存管理中扮演着非常重要的角色,但各自的用途和特点有所不同。
42 0
|
3月前
|
存储 算法 Java
(四)JVM成神路之深入理解虚拟机运行时数据区与内存溢出、内存泄露剖析
前面的文章中重点是对于JVM的子系统进行分析,在之前已经详细的阐述了虚拟机的类加载子系统以及执行引擎子系统,而本篇则准备对于JVM运行时的内存区域以及JVM运行时的内存溢出与内存泄露问题进行全面剖析。
|
6天前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
18 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
2月前
|
存储 算法 Oracle
不好意思!耽误你的十分钟,JVM内存布局还给你
先赞后看,南哥助你Java进阶一大半在2006年加州旧金山的JavaOne大会上,一个由顶级Java开发者组成的周年性研讨会,公司突然宣布将开放Java的源代码。于是,下一年顶级项目OpenJDK诞生。Java生态发展被打开了新的大门,Java 7的G1垃圾回收器、Java 8的Lambda表达式和流API…大家好,我是南哥。一个Java学习与进阶的领路人,相信对你通关面试、拿下Offer进入心心念念的公司有所帮助。
不好意思!耽误你的十分钟,JVM内存布局还给你
|
2月前
|
存储 算法 Java
JVM自动内存管理之垃圾收集算法
文章概述了JVM内存管理和垃圾收集的基本概念,提供一个关于JVM内存管理和垃圾收集的基础理解框架。
JVM自动内存管理之垃圾收集算法