【JVM篇】怎么解决内存泄漏问题

文章目录

🔎什么是内存泄漏

在Java中如果不再使用一个对象,但是这个对象仍然在GC Root的引用链上,这个对象就不会被垃圾回收器回收,这种情况就是内存泄漏

少量的内存泄漏可以容忍,但是如果发生了持续的内存泄漏,不管有多大的内存迟早都会被消耗完,最终导致内存溢出

🛸解决内存泄漏

⭐发现问题

这里我们需要使用VisualVM Laucher这个工具,大家可以自行科普一下使用方法

设置好参数后,然后运行下面的代码

java 复制代码
import java.util.ArrayList;
import java.util.List;

public class OOMDemo {
    private static int _1MB=1024*1024;
    public static void main(String[] args) throws InterruptedException{
        List<Object> objects=new ArrayList<>();
        while (true){
            byte[] bytes=new byte[_1MB];
            //强引用
            objects.add(bytes);
            Thread.sleep(50);
        }
    }
}

然后我们打开工具进行分析

发现我们的堆内存是不断上涨的,这样子就造成了内存泄漏问题

如果我们把强引用这段代码(objects.add(bytes);)注释掉,再次运行看看效果

此时就没有发生内存泄漏问题,堆内存就处在一个相对比较正常的情况

⭐诊断原因

我们可以通过下面的方法生成内存快照文件

然后我们可以使用MAT工具打开hprof文件,来分析内存泄漏的问题

⭐修复问题

相关推荐
彧A11 分钟前
数据库的学习(4)
java·开发语言·数据库
Jinyi50313 分钟前
Spring Boot 高级配置:如何轻松定义和读取自定义配置
java·spring boot·后端·spring·java-ee·maven·intellij-idea
虫小宝18 分钟前
Spring Boot中的API文档生成
java·spring boot·后端
武子康19 分钟前
Hadoop-12-Hive 基本介绍 下载安装配置 MariaDB安装 3台云服务Hadoop集群 架构图 对比SQL HQL
java·大数据·hive·hadoop·分布式·hdfs·mariadb
武子康26 分钟前
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
java·大数据·hadoop·分布式·sql·mapreduce
希昂的学习日记30 分钟前
NIO基础
java·nio
JIAWAP32 分钟前
Linux环境安装Maven
java·linux·centos·maven
年轻的高血压患者34 分钟前
基于Java的水果商品销售网站
java·sql·mysql·servlet·架构·eclipse·idea
*Soo_Young*40 分钟前
【Spring AOP 源码解析前篇】什么是 AOP | 通知类型 | 切点表达式| AOP 如何使用
java·spring·aop
剑海风云1 小时前
GraalVM简介及使用
java·jvm·graalvm·编译器·本地镜像