集合框架(TreeSet存儲Integer類型的元素并遍歷) TreeSet保證元素排序的源碼解析

核心代碼:

 package com.wayboo;

import java.util.TreeSet;

/*
 * TreeSet:能夠?qū)υ匕凑漳撤N規(guī)則進(jìn)行排序榆纽。
 * 排序有兩種方式
 * A:自然排序
 * B:比較器排序
 * 
 * TreeSet集合的特點(diǎn):排序和唯一
 * 
 * 通過觀察TreeSet的add()方法游盲,我們知道最終要看TreeMap的put()方法唁毒。
 */
public class TreeSetDemo {
public static void main(String[] args) {
    // 創(chuàng)建集合對象
    // 自然順序進(jìn)行排序
    TreeSet<Integer> ts = new TreeSet<Integer>();

    // 創(chuàng)建元素并添加
    // 20,18,23,22,17,24,19,18,24
    //自動裝箱
    ts.add(20);
    ts.add(18);
    ts.add(23);
    ts.add(22);
    ts.add(17);
    ts.add(24);
    ts.add(19);
    ts.add(18);
    ts.add(24);

    // 遍歷
    for (Integer i : ts) {
        System.out.println(i);
        }
    }
}

集合框架(TreeSet保證元素排序的源碼解析)

   interface Collection {...}

interface Set extends Collection {...}

interface NavigableMap {

}

class TreeMap implements NavigableMap {
 public V put(K key, V value) {
    Entry<K,V> t = root;
    if (t == null) {
        compare(key, key); // type (and possibly null) check

        root = new Entry<>(key, value, null);
        size = 1;
        modCount++;
        return null;
    }
    int cmp;
    Entry<K,V> parent;
    // split comparator and comparable paths
    Comparator<? super K> cpr = comparator;
    if (cpr != null) {
        do {
            parent = t;
            cmp = cpr.compare(key, t.key);
            if (cmp < 0)
                t = t.left;
            else if (cmp > 0)
                t = t.right;
            else
                return t.setValue(value);
        } while (t != null);
    }
    else {
        if (key == null)
            throw new NullPointerException();
        Comparable<? super K> k = (Comparable<? super K>) key;
        do {
            parent = t;
            cmp = k.compareTo(t.key);
            if (cmp < 0)
                t = t.left;
            else if (cmp > 0)
                t = t.right;
            else
                return t.setValue(value);
        } while (t != null);
    }
    Entry<K,V> e = new Entry<>(key, value, parent);
    if (cmp < 0)
        parent.left = e;
    else
        parent.right = e;
    fixAfterInsertion(e);
    size++;
    modCount++;
    return null;
   }
}

class TreeSet implements Set {
private transient NavigableMap<E,Object> m;

public TreeSet() {
     this(new TreeMap<E,Object>());
}

public boolean add(E e) {
    return m.put(e, PRESENT)==null;
  }
}

真正的比較是依賴于元素的compareTo()方法,而這個方法是定義在 Comparable里面的。
所以致稀,你要想重寫該方法,就必須是先 Comparable接口。這個接口表示的就是自然排序乖坠。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市刀闷,隨后出現(xiàn)的幾起案子熊泵,更是在濱河造成了極大的恐慌,老刑警劉巖甸昏,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件顽分,死亡現(xiàn)場離奇詭異,居然都是意外死亡施蜜,警方通過查閱死者的電腦和手機(jī)卒蘸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人缸沃,你說我怎么就攤上這事恰起。” “怎么了趾牧?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵检盼,是天一觀的道長。 經(jīng)常有香客問我翘单,道長吨枉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任哄芜,我火速辦了婚禮貌亭,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘认臊。我一直安慰自己圃庭,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布美尸。 她就那樣靜靜地躺著冤议,像睡著了一般。 火紅的嫁衣襯著肌膚如雪师坎。 梳的紋絲不亂的頭發(fā)上恕酸,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天,我揣著相機(jī)與錄音胯陋,去河邊找鬼蕊温。 笑死,一個胖子當(dāng)著我的面吹牛遏乔,可吹牛的內(nèi)容都是我干的义矛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼盟萨,長吁一口氣:“原來是場噩夢啊……” “哼凉翻!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起捻激,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤制轰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后胞谭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垃杖,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年丈屹,在試婚紗的時候發(fā)現(xiàn)自己被綠了调俘。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖彩库,靈堂內(nèi)的尸體忽然破棺而出肤无,到底是詐尸還是另有隱情,我是刑警寧澤侧巨,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布舅锄,位于F島的核電站鞭达,受9級特大地震影響司忱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜畴蹭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一坦仍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧叨襟,春花似錦繁扎、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至右犹,卻和暖如春提澎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背念链。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工盼忌, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人掂墓。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓谦纱,卻偏偏與公主長得像,于是被迫代替她去往敵國和親君编。 傳聞我的和親對象是個殘疾皇子跨嘉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件吃嘿、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,093評論 4 62
  • 好頹廢該怎么做不在乎很多事這明明是我一直追求的可怎么終于不在乎了人卻像虛弱到只熟裟耍空殼當(dāng)初的激情都像一攤污水從身體里...
    Mooby_key閱讀 223評論 0 1
  • 鄭學(xué)志老師真有意思,對于畢業(yè)班的高三爛班有一套自己的方法唠椭,培養(yǎng)了學(xué)生的內(nèi)驅(qū)力跳纳,自主學(xué)習(xí)。一個學(xué)生醒悟了贪嫂,突然說自己...
    華燈初上夜微涼閱讀 282評論 3 0
  • 如今信息時代瞬間爆炸寺庄,我們好像已經(jīng)正在淡忘那些手寫的字,可是手寫體的感情又怎么是如今的電子字體可以媲美的? 如果僅...
    語文行者閱讀 738評論 2 4
  • 我為什么從一個熱衷于碎片化學(xué)習(xí)和職業(yè)技能培訓(xùn)課中的好學(xué)生,逃離了出來馍盟。 在某個時候于置,我相信那些不斷吹噓功效的各種課...
    小蝦沒米閱讀 115評論 0 0