本文實例講述了Java TreeSet實作學生按年齡大小和姓名排序的方法。分享給大家參考,具體如下:
import java.util.*; class Treeset { public static void main(String[] args) { TreeSet t = new TreeSet(); t.add(new student("a1",15)); t.add(new student("a2",15)); t.add(new student("a1",15)); t.add(new student("a3",16)); t.add(new student("a3",18)); for(Iterator it = t.iterator();it.hasNext();) { student tt = (student)it.next();//强制转成学生类型 sop(tt.getName()+","+tt.getAge()); } } public static void sop(Object obj) { System.out.println(obj); } } class student implements Comparable//接口让学生具有比较性 { private String name; private int age; student(String name,int age) { this.name = name; this.age = age; } public int compareTo(Object obj) { if(!(obj instanceof student)) throw new RuntimeException("不是学生"); student t = (student)obj; if(this.age > t.age) return 1; if(this.age==t.age) return this.name.compareTo(t.name);//如果年龄相同,在比较姓名排序 return -1; } public String getName() { return name; } public int getAge() { return age; } }
compareTo
# #int compareTo(T o)
sgn(x.compareTo(y)) == -sgn(y.compareTo(x)) 的關係。 (這意味著如果y.compareTo(x) 拋出一個異常,則
x.compareTo(y) 也要拋出一個異常。)
##實現類別也必須確保關係是可傳遞的:(x.compareTo(y)>0 && y.compareTo(z)>0) 意味著x.compareTo(z)>0。
最後,實作者必須確保
x.compareTo(y)==0意味著對於所有的z,都存在sgn(x.compareTo(z)) == sgn(y.compareTo(z))。 強烈建議 (x.compareTo(y)==0) == (x.equals(y)) 這種做法,但並不是 嚴格要求這樣做。一般來說,任何實作 Comparable 介面和違反此條件的類別都應該清楚地指出這一事實。推薦如此闡述:「注意:此類具有與equals 不一致的自然排序。」在前面的描述中,符號
sgn(expression) 指定signum 數學函數,該函數根據expression的值是負數、零或正數,分別傳回-1、0 或1 中的一個值。
o - 要比較的物件。
傳回:負整數、零或正整數,根據此物件是小於、等於或大於指定物件。
拋出:
ClassCastException - 如果指定物件的類型不允許它與此物件進行比較。
以上是Java中使用TreeSet如何實現按年齡大小和姓名排序的範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!