调整JVM堆内存参数
通过修改JVM启动参数增加堆内存大小,适用于物理内存充足的情况。在IDEA的Help > Edit Custom VM Options中添加或修改以下参数:
-Xms512m
-Xmx2048m
-XX:MaxPermSize=512m
-Xms指定初始堆大小,-Xmx指定最大堆大小,建议设置为相同值避免动态调整开销。对于JDK8+项目,用-XX:MaxMetaspaceSize替代-XX:MaxPermSize
优化代码和资源管理
检查是否存在内存泄漏或资源未释放情况。使用try-with-resources自动关闭资源,避免集合类无限增长。特别注意大对象缓存、静态集合、未关闭的IO流等问题。可通过IDEA内置的Analyze > Inspect Code进行潜在内存问题检测
使用内存分析工具
通过MAT(Memory Analyzer Tool)或VisualVM分析堆转储文件。在IDEA运行配置中添加JVM参数生成转储文件:
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=/path/to/dump.hprof
分析转储文件可定位内存消耗最大的对象及引用链
调整编译进程内存
当编译大型项目时出现OOM,需增加编译进程内存。在File > Settings > Build, Execution, Deployment > Compiler中设置:
Build process heap size (Mbytes): 2048
启用G1垃圾回收器
对于JDK9+项目,在VM options中添加:
-XX:+UseG1GC
G1回收器适合大内存场景,能有效减少Full GC停顿时间。可配合调整-XX:MaxGCPauseMillis参数控制GC最大停顿时间
模块化构建大型项目
对于多模块项目,采用增量编译或分模块构建。在File > Settings > Build, Execution, Deployment > Compiler中勾选:
Enable parallel build
Build independent modules in parallel
检查第三方插件内存占用
禁用或更新可能存在内存泄漏的插件。通过File > Settings > Plugins管理已安装插件,观察禁用后内存使用情况变化