内存溢出的排查和定位
内存溢出是一个面试时常问的问题,今天写个小栗子总结一下。
1.内存溢出的例子。
package org.example; import java.util.ArrayList; import java.util.List; public class test2 { public static void main(String[] args) { List<jvmTest> list = new ArrayList<>(); while (true) { list.add(new jvmTest()); // 不断创建对象,导致内存溢出 } } }
如上所示,jvmTest是我自定义的一个类,不断创建对象,最终会导致内存溢出。
2.导出dump文件。
在运行这个main方法的时候加几个参数,如图。
具体参数为:
-Xms20m -Xmx20m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:/dump
这几个参数的意义为,设置JVM堆内存的初始大小和最大值,方便演示,设置内存溢出以后输出dump文件,指定生成的文件路径。
运行以后如图所示:
3.查看dump文件。
打开jdk目录bin目录下面的jvisualvm.exe,点击文件-》装入,打开生成的hprof文件。
如图所示,可以直观的看到是jvmTest这个类占据了大部分内存。导致了内存溢出。
学如逆水行舟,不进则退
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗