一、 SortedSet集合直接舉例 package com.bjpowernode.java_learning; import java.util.*; /** * java.util.Set * java.util.SortedSet;無序不可以重覆,但是存進去的元素可以按照元素大小順序自動進行 ...
一、 SortedSet集合直接舉例
package com.bjpowernode.java_learning; import java.util.*; /** * java.util.Set * java.util.SortedSet;無序不可以重覆,但是存進去的元素可以按照元素大小順序自動進行排列 * java.utile.TreeSet; */ import java.text.*; public class D89_1_SortedSet { public static void main(String[] args) throws ParseException{ //創建集合 SortedSet ss = new TreeSet(); //添加元素 ss.add(10);//自動裝箱 ss.add(12); ss.add(5); ss.add(78); Iterator i = ss.iterator(); while(i.hasNext()) { Object element = i.next(); System.out.println(element); } //String SortedSet sts = new TreeSet(); sts.add("Jack"); sts.add("SUN"); sts.add("COOK"); sts.add("LUCKY"); Iterator i2 = sts.iterator(); while(i2.hasNext()) { Object element = i2.next(); System.out.println(element); } //日期Date String t1 = "2008-08-08"; String t2 = "2009-08-08"; String t3 = "2008-09-08"; SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Date dt1 = sdf.parse(t1); Date dt2 = sdf.parse(t2); Date dt3 = sdf.parse(t3); SortedSet sss = new TreeSet(); sss.add(t1); sss.add(t2); sss.add(t3); //遍歷 Iterator its = sss.iterator(); while(its.hasNext()) { Object element = its.next(); if(element instanceof Date) { Date d = (Date)element; System.out.println(sdf.format(d)); } } } }
二、實現Comparable介面
1.SortedSet集合存儲元素為什麼可以進行自動排序
因為被存儲的元素實現了Comparable介面,SUN編寫TreeSet集合在添加元素的時候,會調用compareTo方法完成比較。
package com.bjpowernode.java_learning; import java.util.*; import java.lang.*; public class D89_2_ImplementComparable { public static void main(String[] args) { SortedSet s = new TreeSet(); User89 u1 = new User89(3); User89 u2 = new User89(45); User89 u3 = new User89(12); User89 u4 = new User89(25); s.add(u1); s.add(u2); s.add(u3); s.add(u4); Iterator i = s.iterator(); while(i.hasNext()) { Object o = i.next(); System.out.println(o.toString()); } } } class User89 implements Comparable{ int age; User89(int age){ this.age = age; } public String toString() { return age+""; } //實現java.lang.Comparable;介面中的compareTo方法 //該方法程式員負責,SUN提供的程式已經調用了該方法 //需求:按照User89的年齡進行排序 public int compareTo(Object o) { //編寫一個規則 int age1 = this.age; int age2 = ((User89)o).age; return age2-age1; } }
我們改一下最後一行代碼:return age1-age2;
然後編譯運行
總結:我們實現的compareTo方法的時候,它的底層是一個二叉樹
當返回結果大於0,那麼比較的元素就會放在右子樹(相當於比較出來了結果:大於);同理,當返回結果小於0,那麼比較的元素就會放在左子樹;
如果返回零的話,說明這兩個對象是完全相同的,因此只會存儲一個對象。(可以看一看Comparable源碼,瞭解一下)。
三、源碼:
D89_1_SortedSet.java
D89_2_ImplementComparable.java
https://github.com/ruigege66/Java/blob/master/D88_1_HashSetExample.java
https://github.com/ruigege66/Java/blob/master/D89_2_ImplementComparable.java
2.CSDN:https://blog.csdn.net/weixin_44630050
3.博客園:https://www.cnblogs.com/ruigege0000/
4.歡迎關註微信公眾號:傅里葉變換,個人公眾號,僅用於學習交流,後臺回覆”禮包“,獲取大數據學習資料