集合框架(TreeSet存儲(chǔ)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)建集合對(duì)象
    // 自然順序進(jìn)行排序
    TreeSet<Integer> ts = new TreeSet<Integer>();

    // 創(chuàng)建元素并添加
    // 20,18,23,22,17,24,19,18,24
    //自動(dòng)裝箱
    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()方法,而這個(gè)方法是定義在 Comparable里面的。
所以,你要想重寫該方法,就必須是先 Comparable接口。這個(gè)接口表示的就是自然排序。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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