HeapOOM && jvisualvm.exe

复制代码
Heap OOM(堆内存溢出)指 Java 应用因堆内存不足抛出 java.lang.OutOfMemoryError: Java heap space

jvisualvm.exe 是 JDK 自带的图形化工具(位于 $JAVA_HOME/bin/),用于加载并分析该文件定位内存泄漏。‌‌

简单理解,实操,每个人都是不一样,或许我这样的方式更加通俗易懂

package jvm;

import java.util.ArrayList;
import java.util.List;

/**
 * 
java -Xms20m -Xmx20m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./heapdump.hprof HeapOOMDemo


有时候字符集乱码,不行的话吧,注释删除下哈
 * 
 * @author ZengWenFeng
 * @date 2019.03.01
 * @mobile 13805029595
 * @email 117791303@qq.com
 */
public class HeapOOMDemo
{
	// 每次创建一个1MB的byte数组,强引用保存到List中,无法被GC回收
	public static void main(String[] args)
	{
		List<byte[]> list = new ArrayList<byte[]>();
		int count = 0;
		while (true)
		{
			list.add(new byte[1024 * 1024]); // 1MB/个
			System.out.println("已创建对象数:" + (++count) + " MB");
		}
	}
}
复制代码
heapdump.hprof
复制代码
Microsoft Windows [版本 10.0.19045.6216]
(c) Microsoft Corporation。保留所有权利。

C:\Users\Administrator>cd C:\Users\Administrator\Desktop

C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>javac HeapOOMDemo.java
HeapOOMDemo.java:18: 错误: 编码GBK的不可映射字符
        // 姣忔鍒涘缓涓?涓?1MB鐨刡yte鏁扮粍锛屽己寮曠敤淇濆瓨鍒癓ist涓紝鏃犳硶琚獹C鍥炴敹
                  ^
HeapOOMDemo.java:18: 错误: 编码GBK的不可映射字符
        // 姣忔鍒涘缓涓?涓?1MB鐨刡yte鏁扮粍锛屽己寮曠敤淇濆瓨鍒癓ist涓紝鏃犳硶琚獹C鍥炴敹
                    ^
HeapOOMDemo.java:25: 错误: 编码GBK的不可映射字符
                        list.add(new byte[1024 * 1024]); // 1MB/涓?
                                                                 ^
HeapOOMDemo.java:26: 错误: 编码GBK的不可映射字符
                        System.out.println("宸插垱寤哄璞℃暟锛?" + (++count) + " MB");
                                                      ^
4 个错误

C:\Users\Administrator\Desktop>javac -encoding UTF-8 HeapOOMDemo.java

C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>
C:\Users\Administrator\Desktop>java -Xms20m -Xmx20m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./heapdump.hprof HeapOOMDemo
Created 1 MB objects
Created 2 MB objects
Created 3 MB objects
Created 4 MB objects
Created 5 MB objects
Created 6 MB objects
Created 7 MB objects
Created 8 MB objects
Created 9 MB objects
Created 10 MB objects
Created 11 MB objects
Created 12 MB objects
Created 13 MB objects
Created 14 MB objects
Created 15 MB objects
Created 16 MB objects
Created 17 MB objects
java.lang.OutOfMemoryError: Java heap space
Dumping heap to ./heapdump.hprof ...
Heap dump file created [19205389 bytes in 0.009 secs]
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
        at HeapOOMDemo.main(HeapOOMDemo.java:9)

C:\Users\Administrator\Desktop>

JVM 结构图 2019

相关推荐
一条泥憨鱼1 小时前
详解MySQL事务(超详细版)
java·数据库·mysql·spring·maven·后端开发
小此方1 小时前
Re:Linux系统篇(十九)进程篇·四:内核托底与生死交错 ,深度硬核剖析“僵尸”与“孤儿”进程
linux·运维·驱动开发
二哈赛车手9 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
wj3055853789 小时前
课程 9:模型测试记录与 Prompt 策略
linux·人工智能·python·comfyui
栗子~~10 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
abigriver10 小时前
打造 Linux 离线大模型级语音输入法:Whisper.cpp + 3090 显卡加速与 Rime 中英混输终极调优指南
linux·运维·whisper
YDS82910 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
wangqiaowq10 小时前
windows下nginx的安装
linux·服务器·前端
YYRAN_ZZU11 小时前
Petalinux新建自动脚本启动
linux