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

相关推荐
七歌杜金房3 小时前
我终于又有了自己的 Linux 电脑
linux·debian·mac
Flittly9 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了9 小时前
Java 生成二维码解决方案
java·后端
人活一口气14 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP16 小时前
Vibe Coding -- 完整项目案例实操
java
荣码16 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing16 小时前
Google第三方授权登录
java·后端·程序员
明月光81816 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯1 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式