2019独角兽企业重金招聘Python工程师标准>>>
大家先运行下下面这段代码,看看结果
public class MemoryLeak {public static void main(String[] args) throws InterruptedException {new Thread(new Runnable() {@Overridepublic void run() {for (int i = 0; i < 2000; i++) {User user1 = new User();User user2 = new User(); user1.str =user2.str.subList(0, 1);//1、user1中的原str已经不可达,会被GC//2、思考user2中str的其他元素 是否会被回收? users.add(user1);}System.gc();}}).start();Thread.sleep(3000);//让线程先运行while (true) {System.gc();Thread.sleep(3000);}}public static List<User> users = new ArrayList();public static class User {public List<String> str = new ArrayList() {{for (int i = 0; i < 10000; i++)add(String.valueOf(i));}};}
}
先分析下原因为什么OOM,然后再把
这段代码
user1.str =user2.str.subList(0, 1)换成下面这段代码,
user1.str = new ArrayList<String>() {{ add("1"); }}; //同样user1里面的str 是一个元素 “1”
然后再看看结果~~
原理和JDK1.6的String.subString 的BUG 一样!~~~
注:版权所有转载请注明出处http://my.oschina.net/u/926166/blog/538921