首页 > 其他 > 详细

hashMap 方法详解

时间:2015-06-01 18:06:54      阅读:118      评论:0      收藏:0      [点我收藏+]

参考文章 :http://www.iteye.com/topic/754887

 /** 
     * 扩展散列表的容量 
     * @param newCapacity 
     */  
    void resize(int newCapacity) {  
        Entry[] oldTable = table;  
        int oldCapacity = oldTable.length;  
        Entry[] newTable = new Entry[newCapacity];  
        transfer(newTable);  
        table = newTable;  
        threshold = (int) (newCapacity * loadFactor);  
    }  
  
    /** 
     * 重新进行散列 
     * @param newTable 
     */  
    void transfer(Entry[] newTable) {  
        Entry[] src = table;  
        int newCapacity = newTable.length;  
        for (int j = 0; j < src.length; j++) {  
            Entry<K, V> e = src[j];  
            if (e != null) {  
                src[j] = null;  
                do {  
                    Entry<K, V> next = e.next;  
                    int i = indexFor(e.hash, newCapacity);  
                    e.next = newTable[i];  
                    newTable[i] = e;  
                    e = next;  
                } while (e != null);  
            }  
        }  
    }

 

hashMap 方法详解

原文:http://www.cnblogs.com/cici-new/p/4544177.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!