【JVM调优实战100例】01——JVM的介绍与程序计数器

简介: 【JVM调优实战100例】01——JVM的介绍与程序计数器

1.JVM简介

1.1 JVM的作用

JVM的作用如下:

  • 一次编写,处处运行
  • 自动管理内存,垃圾回收

数组下标越界检查,如果允许使用数组下标越界的内存分配方式,那么就可能出现内容覆盖的情况,因此JVM为数组下标越界检查提供了支持机制。

提供多态的底层支持。虚方法表存放着各个方法的实际入口地址。如果某个方法在子类中没有被重写,那子类的虚方法表里面的地址入口和父类相同方法的地址入口是一致的,都指向父类的实际入口地址。如果子类重写了这个方法,子类方法表中的地址将会替换为指向子类实现版本的入口地址。

1.2 JVM、JRE、JDK

三者的区别、联系如下图。

36c725c92d2642bd94e915dd1800feb5.png

1.3 常见的JVM

JVM遵守一系列规范,如有需要,可以自己开发一个JVM,很多大公司有自己的JVM,常见的JVM如下表。其底层实现不尽相同,我们接下来都是针对Hotspot进行讲解。

0a955d15a9ce4a588d8ea7bd9e9bfc99.png

1.4 JVM的学习路线

如下图,JVM主要包括三个部分:类加载器,JVM内存结构与执行引擎。一个类经过编译后,必须有类加载器进行加载。类被放在方法区,类的实例对象则被放在堆中,

堆中对象在调用方法时会用到虚拟机栈、程序计数器和本地方法栈。方法执行时,每行代码由执行引擎中的程序解释器解释执行,方法中的热点代码(频繁调用)会由JIT即时编译器进行优化编译,GC则负责对堆中不再被引用的对象进行垃圾回收。有时JVM还需要与操作系统进行交互,本地方法接口负责这一职责。学习时将按照由易到难的顺序,如下图标注学习:先学习JVM的内存结构,在介绍垃圾回收的过程,再学习java编译过程(如优化),再学习类加载的过程与常见的类加载器,最后介绍程序运行时的优化,即解释器与即时编译器部分。

d7ab41f689b1481186370b2ea56f7888.png

2.程序计数器

作用

程序计数器的作用就是记住程序下一条要执行的jvm指令的地址。计算机中java代码到执行的过程是:源代码转为字节码,二进制字节码转为jvm指令,交给解释器

解释器通过程序计数器获取要解释的字节码地址,将指令转为机器码,由CPU执行;同时程序计数器移到了下一条要执行的指令。java是多线程的,正是程序计数器保证了如果线程失去了cpu,重新获取cpu后解释器就可以知道下一条要执行的指令在哪。


b686ed6bf92646aa8626dd7e9522e35f.png

程序计数器具有如下特点

线程私有,每一个线程都有自己的程序计数器,记录当前线程代码执行到哪了。

java虚拟机中唯一一个不会存在内存溢出的部分。

相关文章
|
3天前
|
监控 算法 Java
Java虚拟机(JVM)使用多种垃圾回收算法来管理内存,以确保程序运行时不会因为内存不足而崩溃。
【6月更文挑战第20天】Java JVM运用多种GC算法,如标记-清除、复制、标记-压缩、分代收集、增量收集、并行收集和并发标记,以自动化内存管理,防止因内存耗尽导致的程序崩溃。这些算法各有优劣,适应不同的性能和资源需求。垃圾回收旨在避免手动内存管理,简化编程。当遇到内存泄漏,可以借助VisualVM、JConsole或MAT等工具监测内存、生成堆转储,分析引用链并定位泄漏源,从而解决问题。
12 4
|
11天前
|
存储 缓存 安全
JVM(三)-运行时数据区(栈、程序计数器)
JVM(三)-运行时数据区(栈、程序计数器)
12 2
|
12天前
|
运维 Java Shell
手工触发Full GC:JVM调优实战指南
本文是关于Java应用性能调优的指南,重点介绍了如何使用`jmap`工具手动触发Full GC。Full GC是对堆内存全面清理的过程,通常在资源紧张时进行以缓解内存压力。文章详细阐述了Full GC的概念,并提供了两种使用`jmap`触发Full GC的方法:通过`-histo:live`选项获取存活对象统计信息,或使用`-dump`选项生成堆转储文件以分析内存状态。同时,文中也提醒注意手动Full GC可能带来的性能开销,建议在生产环境中谨慎操作。
|
2天前
|
监控 算法 Java
JVM调优-简介(一)
JVM调优-简介(一)
3 0
|
16天前
|
Java 应用服务中间件 Linux
Tomcat 调优及 JVM 参数优化
Tomcat 调优及 JVM 参数优化
|
24天前
|
存储 算法 Java
JVM性能调优:内存模型及垃圾收集算法
JVM性能调优:内存模型及垃圾收集算法
29 0
|
25天前
|
Java Linux
JVM堆内存诊断
JVM堆内存诊断
21 0
|
5天前
|
算法 Java
Java垃圾回收(Garbage Collection,GC)是Java虚拟机(JVM)的一种自动内存管理机制,用于在运行时自动回收不再使用的对象所占的内存空间
【6月更文挑战第18天】Java的GC自动回收内存,包括标记清除(产生碎片)、复制(效率低)、标记整理(兼顾连续性与效率)和分代收集(区分新生代和老年代,用不同算法优化)等策略。现代JVM通常采用分代收集,以平衡性能和内存利用率。
31 3
|
11天前
|
算法 安全 Java
JVM系列4-垃圾收集器与内存分配策略(二)
JVM系列4-垃圾收集器与内存分配策略(二)
18 0
JVM系列4-垃圾收集器与内存分配策略(二)
|
17天前
|
存储 Java
JVM内存结构(4)
JVM内存结构
15 1