先看一个例子:
import java.util.HashMap;
import java.util.Map;
import java.util.WeakHashMap;
/**
* Created by zhuhao on 17-9-3.
*/
public class TestWeakHashMap {
public static void main(String[] args) {
String a = new String("a");
String b = new String("b");
HashMap<String,String> map1 = new HashMap<> ( );
WeakHashMap<String,String> map2 = new WeakHashMap<> ( );
map1.put ( a,"aaa" );
map1.put ( b,"bbb" );
map2.put ( a,"aaa" );
map2.put ( b,"bbb" );
map1.remove ( a );
a = null;
b = null;
System.gc ();
for (Map.Entry<String,String> tmp : map1.entrySet ()){
System.out.println (tmp.getKey ()+" "+tmp.getValue ());
}
for (Map.Entry<String,String> tmp : map2.entrySet ()){
System.out.println (tmp.getKey ()+" "+tmp.getValue ());
}
}
}
//输出:
//b bbb
//b bbb
为何WeakHashMap的a键值并没有被移除,但是其值却消失了?
此例子中声明了两个Map对象,一个是HashMap,一个是WeakHashMap,同时向两个map中放入a、b两个对象,当HashMap remove掉a 并且将a、b都指向null时,WeakHashMap中的a将自动被回收掉。出现这个状况的原因是,对于a对象而言,当HashMap remove掉并且将a指向null后,除了WeakHashMap中还保存a外已经没有指向a的指针了,所以WeakHashMap会自动舍弃掉a,而对于b对象虽然指向了null,但HashMap中还有指向b的指针,所以WeakHashMap将会保留。
WeakHashMap是以弱键实现的基于哈希表的 Map。在 WeakHashMap 中,当某个键不再正常使用时,将自动移除其条目。
更精确地说,对于一个给定的键,其映射的存在并不阻止垃圾回收器对该键的丢弃,这就使该键成为可终止的,被终止,然后被回收。
丢弃某个键时,其条目从映射中有效地移除,因此,该类的行为与其他的 Map 实现有所不同。
null 值和 null 键都被支持。该类具有与 HashMap 类相似的性能特征,并具有相同的效能参数初始容量 和加载因子。