WeakHahMap,HashMap和(垃圾回收)Gc

时间:2022-04-17 19:15:40
1.HashMap的问题:
   public class testHashMap{        public static HashMap map;
public static void main(String[] args){
addItem();
//下面如何得到放入HashMap的值 tempValue?
//问题代码:map.get(tempKey)?
}
public static void addItem(){
//下面这句必须是new,如果仅仅是常量,则在map中仍然可以引用它。
String tempKey=new String("test1");
//下面这句可以不new
String tempValue=new String("123");
map.put(tempKey,tempValue);
}
}

    更严重的问题是,很多人以为垃圾回收器会去回收HashMap中无用的键?其实不会!!!
2.Java Core Code中提到的解决方案:
        WeakHashMap
    它回去回收无用的键和值。
3.WeakHashMap的问题:
     如果一个键真的是有用呢?而且仅仅是它对应的值在引用它!!
    伪代码:    
    
    class A{
String id;
public A(String id){
id=id;
}
}
class Test{
public static void addItem(){
String id=new String("abc");
A a=new A(id);
//关键地方:
map.put(a.id,a);
}
}

     垃圾回收器仍然不去回收这个无用的键和值。
//结论:
     1.HashMap 的键最好使用Const String,或者int等值型变量,不要用引用型变量。如果必须使用,则需要保证不用的时候将其键值对remove掉。(map.remove)
     2.WeakHashMap 可使用对象作为key,但是,如果符合如下条件将不回收:
        垃圾回收器认为除了键之外有地方在引用它,就像上面a.id在a中有引用。
//真正的感想: .以上只是个人的极端假想,在编程中,很少使用对像做为Key,除了“Const String“。
         本人因为太无聊,所以来研究了这些无聊的问题,这些问题怎么可能会在变成中出现??????
         因为我的Key从来都是Const String!!!!
         如果大侠们的"Key"习惯跟我不一样,敬请浏览一下上面代码,还望多多指教!
               

       欢迎交流。