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

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

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

    狂淘

    www.kuangtao.net

       :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      6 隨筆 :: 185 文章 :: 68 評論 :: 0 Trackbacks

    1 HashMap不是線程安全的


                hastmap是一個接口 是map接口的子接口,是將鍵映射到值的對象,其中鍵和值都是對象,并且不能包含重復鍵,但可以包含重復值。HashMap允許null key和null value,而hashtable不允許。


    2   HashTable是線程安全的一個Collection。


    HashMap是Hashtable的輕量級實現(非線程安全的實現),他們都完成了Map接口,主要區別在于HashMap允許空(null)鍵值(key),由于非線程安全,效率上可能高于Hashtable。
    HashMap允許將null作為一個entry的key或者value,而Hashtable不允許。
    HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因為contains方法容易讓人引起誤解。
    Hashtable繼承自Dictionary類,而HashMap是Java1.2引進的Map interface的一個實現。
    最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多個線程訪問Hashtable時,不需要自己為它的方法實現同步,而HashMap 就必須為之提供外同步。
    Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會有很大的差異。


    public static void main(String args[])
    {
    HashTable h=new HashTable();
    h.put("用戶1",new Integer(90));
    h.put("用戶2",new Integer(50));
    h.put("用戶3",new Integer(60));
    h.put("用戶4",new Integer(70));
    h.put("用戶5",new Integer(80));
    Enumeration e=h.elements();
    while(e.hasMoreElements()){
    System.out.println(e.nextElement());
    }


    map 的方法:


    clear()從 Map 中刪除所有映射


    remove(Object key)從 Map 中刪除鍵和關聯的值


           put(Object key, Object value)將指定值與指定鍵相關聯

    get(Object key)返回與指定鍵關聯的值


    containsKey(Object key)如果 Map 包含指定鍵的映射,則返回 true

     


     


    containsValue(Object value)如果此 Map 將一個或多個鍵映射到指定值,則返回 true


    isEmpty()如果 Map 不包含鍵-值映射,則返回 true size()返回 Map 中的鍵-值映射的數目





    這些都代表了Java中的集合,這里主要從其元素是否有序,是否可重復來進行區別記憶,以便恰當地使用,當然還存在同步方面的差異,見上一篇相關文章。





    有序否


    允許元素重復否


    Collection




    List




    Set


    AbstractSet




    HashSet


    TreeSet


    是(用二叉樹排序)


    Map


    AbstractMap



    使用key-value來映射和存儲數據,Key必須惟一,value可以重復


    HashMap


    TreeMap


    是(用二叉樹排序)


     

     


     


    List 接口對Collection進行了簡單的擴充,它的具體實現類常用的有ArrayList和LinkedList。你可以將任何東西放到一個List容器中,并在需要時從中取出。ArrayList從其命名中可以看出它是一種類似數組的形式進行存儲,因此它的隨機訪問速度極快,而LinkedList的內部實現是鏈表,它適合于在鏈表中間需要頻繁進行插入和刪除操作。在具體應用時可以根據需要自由選擇。前面說的Iterator只能對容器進行向前遍歷,而 ListIterator則繼承了Iterator的思想,并提供了對List進行雙向遍歷的方法。

    Set接口也是 Collection的一種擴展,而與List不同的時,在Set中的對象元素不能重復,也就是說你不能把同樣的東西兩次放入同一個Set容器中。它的常用具體實現有HashSet和TreeSet類。HashSet能快速定位一個元素,但是你放到HashSet中的對象需要實現hashCode()方法,它使用了前面說過的哈希碼的算法。而TreeSet則將放入其中的元素按序存放,這就要求你放入其中的對象是可排序的,這就用到了集合框架提供的另外兩個實用類Comparable和Comparator。一個類是可排序的,它就應該實現Comparable接口。有時多個類具有相同的排序算法,那就不需要在每分別重復定義相同的排序算法,只要實現Comparator接口即可。集合框架中還有兩個很實用的公用類:Collections和 Arrays。Collections提供了對一個Collection容器進行諸如排序、復制、查找和填充等一些非常有用的方法,Arrays則是對一個數組進行類似的操作。


                Map是一種把鍵對象和值對象進行關聯的容器,而一個值對象又可以是一個Map,依次類推,這樣就可形成一個多級映射。對于鍵對象來說,像Set一樣,一個Map容器中的鍵對象不允許重復,這是為了保持查找結果的一致性;如果有兩個鍵對象一樣,那你想得到那個鍵對象所對應的值對象時就有問題了,可能你得到的并不是你想的那個值對象,結果會造成混亂,所以鍵的唯一性很重要,也是符合集合的性質的。當然在使用過程中,某個鍵所對應的值對象可能會發生變化,這時會按照最后一次修改的值對象與鍵對應。對于值對象則沒有唯一性的要求。你可以將任意多個鍵都映射到一個值對象上,這不會發生任何問題(不過對你的使用卻可能會造成不便,你不知道你得到的到底是那一個鍵所對應的值對象)。Map有兩種比較常用的實現: HashMap和TreeMap。HashMap也用到了哈希碼的算法,以便快速查找一個鍵,TreeMap則是對鍵按序存放,因此它便有一些擴展的方法,比如firstKey(),lastKey()等,你還可以從TreeMap中指定一個范圍以取得其子Map。鍵和值的關聯很簡單,用pub (Object key,Object value)方法即可將一個鍵與一個值對象相關聯。用get(Object key)可得到與此key對象所對應的值對象。

     

    posted on 2009-09-21 10:23 狂淘 閱讀(184) 評論(0)  編輯  收藏 所屬分類: jsp項目 傳到服務器問題
    主站蜘蛛池模板: 美女免费视频一区二区三区| 亚洲日韩在线视频| 自拍偷自拍亚洲精品播放| 我要看WWW免费看插插视频| 亚洲国产精品人久久电影 | 麻豆精品成人免费国产片| 亚洲性久久久影院| 国产一二三四区乱码免费| 在线亚洲午夜理论AV大片| 免费无码作爱视频| 精品无码一区二区三区亚洲桃色 | 一级特黄录像视频免费| 亚洲成a人片在线观看久| 中美日韩在线网免费毛片视频 | 日韩在线视频免费| 久久青青草原亚洲av无码| 免费看少妇高潮成人片| 亚洲最大黄色网址| 在线观看国产情趣免费视频| 直接进入免费看黄的网站| 亚洲女久久久噜噜噜熟女| 9420免费高清在线视频| 亚洲熟女乱色一区二区三区| 国产免费人视频在线观看免费| 又大又硬又粗又黄的视频免费看 | 黄色a三级免费看| 亚洲中文字幕不卡无码| 亚洲电影在线免费观看| 国产精品亚洲专区无码WEB| 亚洲色偷偷狠狠综合网| 99久久免费中文字幕精品| 亚洲精品无码国产片| 奇米影视亚洲春色| 国产一卡2卡3卡4卡2021免费观看| 麻豆69堂免费视频| 一区二区三区亚洲| 亚洲AV无码乱码在线观看牲色| 久久国产免费一区| 国产亚洲视频在线播放大全| 亚洲宅男永久在线| 四虎永久免费影院在线|