JVM 深入理解与性能优化

embedded/2025/2/27 16:56:03/

JVM(Java Virtual Machine,Java 虚拟机)是 Java 代码运行的核心,它负责 内存管理、类加载、字节码执行、垃圾回收(GC)和 JIT 编译。理解 JVM 有助于优化 Java 应用的性能,提高调试和排错能力。

内存管理

JVM 在运行时会将内存划分成不同的区域,每个区域有不同的作用:

注:图片来自于网络

  • 方法区(Metaspace):存储类元数据(方法、字段、常量池等)。

  • 堆(Heap):存储对象实例,GC 主要管理的区域,分为 新生代(Eden、S0、S1)老年代

  • 虚拟机栈(Stack):存储方法调用的局部变量、操作数栈、方法返回地址。

  • 本地方法栈(Native Stack):用于执行 JNI(Java Native Interface)方法。

  • 程序计数器(PC Register):记录当前执行的字节码指令地址。

🌟 实战案例:栈溢出
java">public class StackOverflowDemo {public static void recursiveMethod() {recursiveMethod(); // 无限递归,导致栈溢出}public static void main(String[] args) {recursiveMethod();}
}

运行后会抛出 **java.lang.StackOverflowError**,因为栈空间被耗尽。

类加载机制

JVM 通过 类加载器(ClassLoader) 加载 .class 文件到内存。

类加载过程

注:图片来自于网络

  1. 加载(Loading):从文件或网络加载字节码。

  2. 验证(Verification):检查字节码格式和安全性。

  3. 准备(Preparation):为类的静态变量分配内存并初始化默认值。

  4. 解析(Resolution):解析符号引用。

  5. 初始化(Initialization):执行 <clinit> 静态代码块。

双亲委派机制

注:图片来自于网络

  • BootstrapClassLoader(加载核心类,如 java.lang.*

  • ExtClassLoader(加载 ext 目录的扩展类)

  • AppClassLoader(加载 classpath 下的类)

  • 自定义 ClassLoader(可以破坏双亲委派机制)

🌟 实战案例:自定义类加载器
java">import java.io.*;
​
public class MyClassLoader extends ClassLoader {@Overridepublic Class<?> findClass(String name) throws ClassNotFoundException {byte[] bytes = loadClassData(name);return defineClass(name, bytes, 0, bytes.length);}private byte[] loadClassData(String name) {try (InputStream input = new FileInputStream(name + ".class")) {ByteArrayOutputStream output = new ByteArrayOutputStream();byte[] buffer = new byte[1024];int bytesRead;while ((bytesRead = input.read(buffer)) != -1) {output.write(buffer, 0, bytesRead);}return output.toByteArray();} catch (IOException e) {throw new RuntimeException(e);}}
}

JVM 垃圾回收(GC)机制

JVM 通过 GC 自动管理对象的内存回收,常见 GC 方式:

  • Minor GC(年轻代回收)

  • Major GC(Full GC)(老年代回收)

垃圾回收算法
  • 标记-清除(Mark-Sweep):标记不可达对象并回收。

  • 复制(Copying):将存活对象复制到新空间,适用于新生代。

  • 标记-整理(Mark-Compact):回收对象并整理内存,适用于老年代。

常见垃圾回收器
GC 类型适用场景说明
Serial GC小型应用单线程
Parallel GC高吞吐量多线程
CMS GC低延迟应用并发回收
G1 GC大内存低停顿
🌟 实战案例:GC 日志分析
java -XX:+PrintGCDetails -Xms100M -Xmx100M -XX:+UseG1GC MyApplication

JIT(Just-In-Time)编译优化

JVM 采用 JIT(即时编译) 优化代码执行。

  • C1 编译器:轻量级优化,适用于客户端模式。

  • C2 编译器:高性能优化,适用于服务器模式。

  • 逃逸分析(Escape Analysis)

    • 栈上分配(减少堆内存使用)

    • 标量替换(减少对象创建)

JVM 调优与性能优化

JVM 监控工具
  • jps:查看 JVM 进程

  • jmap:查看内存快照

  • jstack:查看线程栈

  • VisualVM:可视化 JVM 监控工具

JVM 常用调优参数
-XX:+PrintGCDetails -Xms512m -Xmx1024m -XX:+UseG1GC

实战+总结

🌟 JVM 调优案例
java -Xms512m -Xmx1g -XX:+UseG1GC -XX:+PrintGCDetails MyApplication

观察 GC 运行情况,调整参数优化性能。

📌 总结
  1. 内存管理:JVM 运行时分为 堆、方法区、栈、本地方法栈、程序计数器

  2. 类加载机制:包括 类加载过程和双亲委派

  3. 垃圾回收(GC):JVM 通过 GC Roots 进行 可达性分析,采用不同 GC 算法和回收器

  4. JIT 编译:即时编译优化 Java 代码,提高执行效率。

  5. JVM 调优:使用 VisualVMjstat 监控,优化 GC 参数。


http://www.ppmy.cn/embedded/167576.html

相关文章

34.Java 阻塞队列(阻塞队列架构、阻塞队列分类、阻塞队列核心方法)

一、阻塞队列概述 java.util.concurrent 包下的 BlockingQueue 接口很好的解决了多线程中如何高效安全传输数据的问题&#xff0c;可以使用这些高效并且线程安全的队列类快速搭建高质量的多线程程序 阻塞队列通过一个共享的队列&#xff0c;使得数据由队列的一端输入&#xff…

Java HTTP 请求的四种实现方式:Apache HttpClient、OkHttp、WebClient 与 Java 11 HttpClient

目录 1.使用Java11内置的HttpClient 2.使用OkHttp 3.使用SpringWebClient 4.使用ApacheHttpClient5.x 在现代Java开发中&#xff0c;HttpClient和PostMethod是较旧的ApacheHttpClient3.x的API。推荐使用更现代的技术来替代这些代码&#xff0c;例如Java11内置的HttpClient或…

QT零基础学习之路(四)--信号和槽机制

源码&#xff08;更新更快&#xff09;&#xff1a;https://mp.weixin.qq.com/s/LvcjGiK6KSyoAB55qosgIQ

自然语言处理(NLP):文本向量化从文字到数字的原理

在人工智能领域&#xff0c;尤其是自然语言处理&#xff08;NLP&#xff09;中&#xff0c;将文本信息转化为机器可以理解的形式是一个至关重要的步骤。本文探讨如何将文本转换为向量表示的过程&#xff0c;包括分词、ID映射、One-hot编码以及最终的词嵌入&#xff08;Embeddin…

126.单词接龙Ⅱ python

单词接龙Ⅱ 题目题目描述示例 1&#xff1a;示例 2&#xff1a;提示&#xff1a; 题解解决方案步骤Python 实现解释提交结果 题目 题目描述 按字典 wordList 完成从单词 beginWord 到单词 endWord 转化&#xff0c;一个表示此过程的 转换序列 是形式上像 beginWord -> s1 …

软件供应链安全工具链研究系列—RASP自适应威胁免疫平台(下篇)

在“软件供应链安全工具链研究系列—RASP自适应威胁免疫平台-上篇”中我们提到了RASP工具的基本能力、原理以及工具的应用场景&#xff0c;了解到了RASP工具在各场景下发挥的价值。那么在当今高强度攻防对抗的大场景下&#xff0c;RASP作为最后一道防线&#xff0c;不论是从高危…

系统架构设计:软件测试需要掌握的常用方法

软件测试是软件开发过程中不可或缺的一部分,其目的是确保软件产品的质量和性能。本文将详细介绍软件测试的重要知识点,并附上相关代码示例,帮助读者更好地理解和应用这些知识。 一、软件测试的定义与目的 1. 定义 软件测试是在规定的条件下对程序进行操作,以发现程序错误…

DeepSeek动画视频全攻略:从架构到本地部署

DeepSeek 本身并不直接生成动画视频,而是通过与一系列先进的 AI 工具和传统软件协作,完成动画视频的制作任务。这一独特的架构模式,使得 DeepSeek 在动画视频创作领域发挥着不可或缺的辅助作用。其核心流程主要包括脚本生成、画面设计、视频合成与后期处理这几个关键环节。 …