我想测试Java WeakHashMap类的功能,为此我编写了以下测试:
public class WeakHashMapTest {
public static void main(String args[]) {
Map<String, Object> weakMap = new WeakHashMap<>();
String x = new String("x");
String x1 = new String("x1");
String x2 = new String("x2");
weakMap.put(x, x);
weakMap.put(x1, x1);
weakMap.put(x2, x2);
System.out.println("Map size :" + weakMap.size());
// force all keys be eligible
x=x1=x2=null;
// call garbage collector
System.gc();
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("Map size :" + weakMap.size());
System.out.println("Map :" + weakMap);
}
}
在运行WeakMapTest类之后,我惊讶地发现输出如下:
垃圾回收前的映射:{x=x,x1=x1,x2=x2} 垃圾回收后的映射:{x=x,x1=x1,x2=x2}
我本以为这个映射将为空。
也就是说,垃圾回收器没有起作用。但是为什么呢?