大家先运行下下面这段代码,看看结果
public class MemoryLeak {
public static void main(String[] args) throws InterruptedException {
new Thread(new Runnable() {
@Override
public 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