首頁  >  文章  >  Java  >  Java中使用TreeSet如何實現按年齡大小和姓名排序的範例

Java中使用TreeSet如何實現按年齡大小和姓名排序的範例

黄舟
黄舟原創
2017-09-07 10:25:372832瀏覽

本文實例講述了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)

比較此物件與指定物件的順序。如果該對像小於、等於或大於指定對象,則分別傳回負整數、零或正整數。

實作類別必須確保對所有的 x 和 y 都存在

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn