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

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

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

    dream.in.java

    能以不變應萬變是聰明人做事的準則。萬事從小事做起,積累小成功,問鼎大成功,是成功者的秘訣。

    Map的疑惑

    from url: http://hi.baidu.com/bluetcw/blog/item/6030cf1f49e1da66f724e401.html

    import java.util.Map;

    public class EnvMap {
        public static void main (String[] args) {
            Map<String, String> env = System.getenv();
            for (String envName : env.keySet()) {
                System.out.format("%s=%s%n", envName, env.get(envName));
            }
        }
    }

    本來在java tutorial看到這個例程倒沒什么問題,仔細看了一下MAP的文檔,
    The Map interface provides three collection views, which allow a
    map's contents to be viewed as a set of keys, collection of values,
    or set of key-value mappings.
    這個就不明白了,set of keys,是不是說keys的不重復性,那collection of values呢?
    表明每個key只有一個value?不太明白這里的set和collection是不是要表達Collection接口
    和set接口的含義呢?

    引用一些概念的解釋:

    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-04-05 12:50 YXY 閱讀(162) 評論(0)  編輯  收藏


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


    網站導航:
    博客園   IT新聞   Chat2DB   C++博客   博問  
     
    主站蜘蛛池模板: 91大神亚洲影视在线| 青青青青青青久久久免费观看| 国产成人亚洲综合| 精品国产日韩亚洲一区91| 日韩一区二区免费视频| 国产精品亚洲va在线观看| 无码不卡亚洲成?人片| 国产黄片不卡免费| 亚洲线精品一区二区三区| 在线看片免费人成视频久网下载| 亚洲色图综合在线| 久久这里只精品99re免费 | 亚洲成A人片在线观看无码3D| 国产成人不卡亚洲精品91| 亚洲精品麻豆av| 丁香花在线视频观看免费| 亚洲欧洲日产国产综合网| 日本人的色道免费网站| 97se亚洲国产综合自在线| 国产又长又粗又爽免费视频| 四虎影视久久久免费观看| 亚洲精品~无码抽插| 亚洲黄色免费观看| 亚洲日本久久久午夜精品| 又大又黄又粗又爽的免费视频| eeuss免费天堂影院| 久久精品a亚洲国产v高清不卡 | 黄网站色视频免费看无下截| 相泽亚洲一区中文字幕| 99re6在线精品视频免费播放 | 亚洲AV无码乱码在线观看牲色| a毛片在线看片免费| 激情综合亚洲色婷婷五月APP| 免费中文字幕在线观看| 午夜视频在线免费观看| 亚洲精品中文字幕无码A片老| 亚洲色WWW成人永久网址| 国产男女爽爽爽爽爽免费视频| 黄色毛片免费网站| 亚洲综合男人的天堂色婷婷| 国产一区二区三区免费在线观看|