TreeSet和HashSet的區(qū)別

TreeSet用法

TreeSet可以用于元素進(jìn)行排序及保證元素唯一,可以用過對象實(shí)現(xiàn)Comparable接口哎壳,或者new TreeSet的時(shí)候傳入自定義的比較方法,實(shí)現(xiàn)自定義的排序。

public class TreeSetTest {
    public static void main(String[] args){
        TreeSet treeSet=new TreeSet();
//        treeSet.add("aa");
//        treeSet.add("qqq");
//        treeSet.add("pppp");
//        treeSet.add("aa");
//        System.out.println(treeSet);
        //自定義對象比較
        treeSet.add(new Person("張三",7));
        treeSet.add(new Person("李四",888));
        treeSet.add(new Person("王五",99));
        treeSet.add(new Person("方六",7));
        System.out.println(treeSet);
        //輸出  [Person{name='張三', age=7}, Person{name='方六', age=7}, Person{name='王五', age=99}, Person{name='李四', age=888}]

        //compareTo比較的是字符的大小异逐,char的值
        System.out.println("張三".compareTo("李四"));

        System.out.println("------------------------------");
        //元素也可以通過傳入比較的方法忍抽,實(shí)現(xiàn)自定義的比較
        TreeSet treeSet2=new TreeSet(new CompareByLen());
        treeSet2.add("aasss");
        treeSet2.add("bb");
        treeSet2.add("ppppp");
        treeSet2.add("nnn");
        System.out.println(treeSet2);
       //輸出: [bb, nnn, aasss, ppppp]


    }

    static class CompareByLen  implements Comparator<String> {

        @Override
        public int compare(String s1, String s2) {      //按照字符串的長度比較
            int num = s1.length() - s2.length();        //長度為主要條件
            return num == 0 ? s1.compareTo(s2) : num;   //內(nèi)容為次要條件
        }

    }
}

Person類如下

public class Person implements Comparable<Person>{

    private String name;
    private int age;

    public  Person(String name,int age){
        this.name=name;
        this.age=age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }


    @Override
    public int compareTo(Person o) {
        int num=this.age-o.age;//年齡是第一比較條件
        return num==0?this.name.compareTo(o.name):num;//年齡相等八孝,在比較名字
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

compareTo()是怎么進(jìn)行比較的呢?可以比較中文嗎鸠项?
中文也有自己的ascii碼干跛,也是可以比較的,看看源碼祟绊,是通過比較第一個(gè)字符的ascii碼大小驯鳖,如果相等,再繼續(xù)比較下去


image.png

hashSet用法

  • hashSet基于HashMap實(shí)現(xiàn)久免,以HashSet的值作為HashMap的一個(gè)key,以一個(gè)Object常量作為hashMap的值浅辙。
  • HashSet允許擁有一個(gè)為null的值,HashSet的值不可重復(fù)
  • 在創(chuàng)建HashSet的時(shí)候阎姥,如果合適记舆,最好指定其內(nèi)部HashMap的capacity和loadFactory的值,

重寫equals方法的時(shí)候必須匹配相應(yīng)的hashCode()方法呼巴,因?yàn)槿绻恢貙懙脑捲笕瑫?dǎo)致hash不一致,hashMap會把hash不一致的元素放在不同的位置衣赶,導(dǎo)致判斷對象相等時(shí)取到的對象不一致诊赊,產(chǎn)生兩個(gè)對象。

區(qū)別

1.TreeSet背后的結(jié)構(gòu)是TreeMap,也就是紅黑樹府瞄,能夠?qū)崿F(xiàn)自動排序碧磅。通過equals和compareTo方法進(jìn)行內(nèi)容的比較。
2.HashSet背后是HashMap,key是無序的,只能做外部排序鲸郊。既然是Hash,那么就要重寫其對象的hashCode和equals方法丰榴。

1.HashSet可以接受null值,有且只有一個(gè)
2.TreeSet默認(rèn)不可以接受null值秆撮,會直接拋出空指針異常
3.set里沒有重復(fù)數(shù)據(jù)四濒,TreeSet里連虛無都沒有

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市职辨,隨后出現(xiàn)的幾起案子盗蟆,更是在濱河造成了極大的恐慌,老刑警劉巖舒裤,帶你破解...
    沈念sama閱讀 219,270評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喳资,死亡現(xiàn)場離奇詭異,居然都是意外死亡惭每,警方通過查閱死者的電腦和手機(jī)骨饿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來台腥,“玉大人宏赘,你說我怎么就攤上這事±璩蓿” “怎么了察署?”我有些...
    開封第一講書人閱讀 165,630評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長峻汉。 經(jīng)常有香客問我贴汪,道長,這世上最難降的妖魔是什么休吠? 我笑而不...
    開封第一講書人閱讀 58,906評論 1 295
  • 正文 為了忘掉前任扳埂,我火速辦了婚禮,結(jié)果婚禮上瘤礁,老公的妹妹穿的比我還像新娘阳懂。我一直安慰自己,他們只是感情好柜思,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評論 6 392
  • 文/花漫 我一把揭開白布贡这。 她就那樣靜靜地躺著蛛蒙,像睡著了一般俯艰。 火紅的嫁衣襯著肌膚如雪权悟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,718評論 1 305
  • 那天陨享,我揣著相機(jī)與錄音葱淳,去河邊找鬼钝腺。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蛙紫,可吹牛的內(nèi)容都是我干的拍屑。 我是一名探鬼主播途戒,決...
    沈念sama閱讀 40,442評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼坑傅,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了喷斋?” 一聲冷哼從身側(cè)響起唁毒,我...
    開封第一講書人閱讀 39,345評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎星爪,沒想到半個(gè)月后浆西,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,802評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡顽腾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評論 3 337
  • 正文 我和宋清朗相戀三年近零,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抄肖。...
    茶點(diǎn)故事閱讀 40,117評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡久信,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出漓摩,到底是詐尸還是另有隱情裙士,我是刑警寧澤,帶...
    沈念sama閱讀 35,810評論 5 346
  • 正文 年R本政府宣布管毙,位于F島的核電站腿椎,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏夭咬。R本人自食惡果不足惜啃炸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望卓舵。 院中可真熱鬧南用,春花似錦、人聲如沸边器。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忘巧。三九已至恒界,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間砚嘴,已是汗流浹背十酣。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評論 1 272
  • 我被黑心中介騙來泰國打工涩拙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人耸采。 一個(gè)月前我還...
    沈念sama閱讀 48,377評論 3 373
  • 正文 我出身青樓兴泥,卻偏偏與公主長得像,于是被迫代替她去往敵國和親虾宇。 傳聞我的和親對象是個(gè)殘疾皇子搓彻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評論 2 355

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

  • Java集合類可用于存儲數(shù)量不等的對象,并可以實(shí)現(xiàn)常用的數(shù)據(jù)結(jié)構(gòu)如棧,隊(duì)列等,Java集合還可以用于保存具有映射關(guān)...
    小徐andorid閱讀 1,942評論 0 13
  • 1. HashMap與HashTable的區(qū)別? 1.HashMap是非線程安全的,HashTable是線程安全的...
    WinkTink閱讀 1,155評論 0 1
  • 1.Java集合框架是什么嘱朽?說出一些集合框架的優(yōu)點(diǎn)旭贬? 每種編程語言中都有集合,最初的Java版本包含幾種集合類:V...
    Oneisall_81a5閱讀 901評論 0 11
  • 今天是情人節(jié)~那么搪泳,先祝大家情人節(jié)快樂呀~哪怕沒有情人也不妨礙你的快樂哇⊙ω⊙~ 今天也是我第一天上班稀轨,新入職...
    Fanyi_伊凡閱讀 379評論 0 1
  • 青春就是這樣,好到無論你怎樣過都會覺的缺憾岸军。 在見習(xí)結(jié)束之際奋刽,如臨大敵般的應(yīng)對內(nèi)外婦兒傳染病的大招,實(shí)習(xí)倒...
    AceofHearts閱讀 339評論 0 0