<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    和風(fēng)細雨

    世上本無難事,心以為難,斯乃真難。茍不存一難之見于心,則運用之術(shù)自出。

    HashMap和Hashtable的實驗比較結(jié)果

    面試題中常有HashMap和Hashtable的異同比較題,今天閑著無事,做了一點小比較,實驗結(jié)果如下:
       HashMap  Hashtable
     允許空鍵  允許  不允許
     允許空值  允許  不允許
     以空鍵取值  能取到值  
     取空值  能取得  
     插值速度  稍高  稍低
     取值速度  高  低
     遍歷速度  兩者差不多 兩者差不多

    測試代碼如下:
    package com.sitinspring;

    import java.util.HashMap;
    import java.util.Hashtable;
    import java.util.Iterator;
    import java.util.Map;

    public class Main {
        
    public static void main(String[] args) {
            Map
    <String, String> hashMap = new HashMap<String, String>();
            Map
    <String, String> hashTable = new Hashtable<String, String>();

            
    // 測試一:往兩者中放空鍵,hashMap允許,hashTable不允許,第二句會拋出空指針異常
            hashMap.put(null"value");
            hashTable.put(
    null"value");

            
    // 測試二:往兩者中放空值,hashMap允許,hashTable不允許,第二句也會拋出空指針異常
            hashMap.put("key"null);
            hashTable.put(
    "key"null);

            
    // 測試三:以空鍵取hashMap中的值,結(jié)果能夠取到"value"
            String value = hashMap.get(null);
            System.out.println(
    "取出的值等于" + value);

            
    // 測試四:以鍵"key"取hashMap中的值,結(jié)果能夠取到null
            String value2 = hashMap.get("key");
            System.out.println(
    "取出的值等于" + value2);
            
            
    // 測試五:插值速度比較,兩者差別不大
            int max=100000;
            
            TimeTest tableTimeTest
    =new TimeTest();
            setValuesToMap(hashTable,max);
            tableTimeTest.end(
    "往hashTable插"+max+"值耗時");
            
            hashMap.clear();
    // 清楚掉原來加入的值        
            TimeTest mapTimeTest=new TimeTest();
            setValuesToMap(hashMap,max);
            mapTimeTest.end(
    "往hashMap插"+max+"個值耗時");        
            
            
    // 測試六:取值速度比較,hashTable速度平均約為hashMap的四分之一到七分之一
            TimeTest tableTimeTest2=new TimeTest();
            getValuesFromMap(hashTable,max);
            tableTimeTest2.end(
    "從hashTable取"+max+"值耗時");
            
            TimeTest mapTimeTest2
    =new TimeTest();
            getValuesFromMap(hashMap,max);
            mapTimeTest2.end(
    "往hashMap取"+max+"個值耗時");    
            
            
    // 測試七:遍歷速度比較,hashTable速度和hashMap的差不多
            TimeTest tableTimeTest3=new TimeTest();
            traversalMap(hashTable);
            tableTimeTest3.end(
    "遍歷hashTable耗時");
            
            TimeTest mapTimeTest3
    =new TimeTest();
            traversalMap(hashMap);
            mapTimeTest3.end(
    "遍歷hashMap耗時");
        }
        
        
    private static void setValuesToMap(Map<String,String> map,int max){
            
    for(int i=0;i<max;i++){
                String str
    =String.valueOf(i);
                map.put(str, str);
            }
        }
        
        
    private static void getValuesFromMap(Map<String,String> map,int max){
            
    for(int i=0;i<max;i++){
                String str
    =map.get(i);
            }
        }
        
        
    private static void traversalMap(Map<String,String> map){
            Iterator it
    =map.keySet().iterator();
            
            
    while(it.hasNext()){
                String key
    =(String)it.next();
                String value
    =map.get(key);
            }
        }
    }

    package com.sitinspring;

    import java.util.Calendar;
    import java.util.GregorianCalendar;

    public class TimeTest {
        
    private Calendar startTime;

        
    public TimeTest() {
            startTime 
    = new GregorianCalendar();
        }

        
    public void end(String functionName) {

            Calendar endTime 
    = new GregorianCalendar();

            
    int miniteSpan = endTime.get(Calendar.MINUTE)
                    
    - startTime.get(Calendar.MINUTE);
            
    int secondSpan = endTime.get(Calendar.SECOND)
                    
    - startTime.get(Calendar.SECOND);
            
    int msecondSpan = endTime.get(Calendar.MILLISECOND)
                    
    - startTime.get(Calendar.MILLISECOND);

            System.out.println(functionName 
    + " " + String.valueOf(miniteSpan)
                    
    + " 分 " + String.valueOf(secondSpan) + " 秒 "
                    
    + String.valueOf(msecondSpan) + " 毫秒 ");
        }
    }

    代碼下載:
    http://www.tkk7.com/Files/sitinspring/HashMapHashtable20071215212107.rar

    posted on 2008-02-22 10:28 和風(fēng)細雨 閱讀(1021) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 亚洲中文字幕无码一去台湾| 狠狠亚洲婷婷综合色香五月排名| 久久久久久亚洲精品中文字幕| 一道本不卡免费视频| 四虎影永久在线高清免费| 亚洲精品永久在线观看| 暖暖在线日本免费中文| 亚洲AV无码一区二区三区网址| 国产精品va无码免费麻豆| 曰批免费视频播放免费| 亚洲国产综合人成综合网站| 一区二区三区在线观看免费| 亚洲AV成人片色在线观看高潮| 99国产精品视频免费观看| 亚洲春色另类小说| 成年女人喷潮毛片免费播放| 亚洲国产精品无码久久| 亚洲精品在线视频| 久久香蕉国产线看免费| 亚洲成人免费电影| 国产高清视频在线免费观看| 一级黄色免费网站| 亚洲AV人人澡人人爽人人夜夜| 国产精彩免费视频| 亚洲AV无码成人精品区日韩| 精品国产香蕉伊思人在线在线亚洲一区二区| 中文字幕不卡高清免费| 91精品国产亚洲爽啪在线观看| 妞干网在线免费视频| 国产在线观看无码免费视频| 亚洲精品免费在线| 免费jjzz在线播放国产| 中文字幕无码免费久久| 久久国产亚洲精品| 亚洲日产无码中文字幕| 免费无码黄十八禁网站在线观看| 无码AV动漫精品一区二区免费 | 黄色a级片免费看| 亚洲今日精彩视频| 免费一级做a爰片性色毛片| 无码中文字幕av免费放dvd|