一、内存泄漏原因
非静态内部类会有持有外部类,如果有地方引用了这个非静态内部类,会导致外部类也被引用,垃圾回收时无法回收这个外部类(即使外部类已经没有其他地方使用了)
解决方案:
1、不要让其他地方持有这个非静态内部类的引用,直接在这个歌非静态内部类执行业务
2、将这个非静态内部类改为静态内部类,内部类改为静态类之后,他所引用的对象和属性也必须是静态,所以静态内部类无法获得外部对象的引用,只能从JVM的Method Area 方法区获取到static类型的引用。
二、持有内部类,执行到80万次内存泄漏
package com.example.demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import java.util.ArrayList; import java.util.List; @SpringBootApplication public class Demo2Application { public static void main(String[] args) { // SpringApplication.run(Demo2Application.class, // args); List<Object> list = new ArrayList<>(); int a =0; while (true){ Outer.Inner inner = new Outer(1000).createInner(); list.add(inner); a++; System.out.println(a); } } } class Outer{ private String outerName = "yyy"; private int[] Data; public Outer(int size){ Data = new int[size]; } class Inner { // private String name; public Inner(){ // this.name = outerName; } } Inner createInner(){ return new Inner(); } }
三、改为静态类,执行到1亿次无法泄漏内存
package com.example.demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import java.util.ArrayList; import java.util.List; @SpringBootApplication public class Demo2Application { public static void main(String[] args) { // SpringApplication.run(Demo2Application.class, // args); List<Object> list = new ArrayList<>(); int a =0; while (true){ Outer.Inner inner = new Outer(1000).createInner(); list.add(inner); a++; System.out.println(a); } } } class Outer{ private String outerName = "yyy"; private int[] Data; public Outer(int size){ Data = new int[size]; } static class Inner { // private String name; public Inner(){ // this.name = outerName; } } Inner createInner(){ return new Inner(); } }
标签:泄漏,Java,int,内存,Outer,new,import,public,Inner From: https://www.cnblogs.com/topguntopgun/p/16770214.html