實現Comparator方式排序


import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;


public class TreetDemo {
public static void main(String[] args) {
TreeSet ts=new TreeSet(new MyCompare());
ts.add(new Student1("張三005",22));
ts.add(new Student1("張三004",25));
ts.add(new Student1("張三003",24));
ts.add(new Student1("張三004",23));
ts.add(new Student1("張三001",23));

//System.out.println(ts);
//迭代方法取出集合中的元素
Iterator it=ts.iterator();
System.out.println("按照名字排序的結果為:");
while(it.hasNext())
{
Student1 stu=(Student1)it.next();
System.out.println(stu.getName()+"::"+stu.getAge());
}
}
}
//自定義對象
class Student1 implements Comparable
{
private String name;
private int age;
Student1(String name,int age)
{
this.name=name;
this.age=age;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
@Override
public int compareTo(Object obj) {
// TODO 自動生成的方法存根
if(!(obj instanceof Student1))
{
throw new RuntimeException("不是學生對象");
}
Student1 s=(Student1)obj;
System.out.println(this.name+".....compare to........"+s.name);
if(this.age>s.age)
return 1;
if(this.age==s.age)
{
//排序時,當主要條件相同時,一定要判斷一下次要條件
//如果不加上這句話,輸出時,年齡相同的元素輸出一個
return this.name.compareTo(s.name);
}
//return 0; //系統認為兩個是相同對象,視為一個
return -1;
}
}
//自定義方法通過name來做排序的依據
class MyCompare implements Comparator
{
@Override
public int compare(Object o1, Object o2) {
// TODO 自動生成的方法存根
Student1 s1=(Student1)o1;
Student1 s2=(Student1)o2;
int num=s1.getName().compareTo(s2.getName());
if(num==0)
{
return new Integer(s1.getAge()).compareTo(new Integer(s2.getAge()));
/*if(s1.getAge()>s2.getAge())
return 1;
if(s1.getAge()==s2.getAge())
return 0;
return -1;*/
}
return num;
}
}


結果:



注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
粤ICP备14056181号  © 2014-2021 ITdaan.com