package day01_10;
import java.util.Comparator;
import java.util.Set;
import java.util.TreeSet;
public class Test_SortedSet {
public static void main(String[] args) {
//返回0 则代表两个字符串相等
//System.out.println("hello".compareTo("hello"));
//TreeSet是SortedSet (Set的子接口)的实现类
Comparator<Worker> k = new Comparator<Worker>(){
//if w1.age-w2.age:负数
//if w1.age-w2.age:0
//if w1.age-w2.age:正数
//如果比较两个对象是否相同,无非就是比较属性,这里就是比较name和age是否相等,返回0。如果相等则表示
//是同一个对象
@Override
public int compare(Worker w1, Worker w2) {
//w1.age-w2.age 如果返回的是0 那么表明w1和w2对象相同 则就会去从 但是容易造成误杀
//return w1.age-w2.age;
if (w1.age!=w2.age) return w1.age-w2.age; //如果年龄相等,就进一步比较姓名
else return w1.name.compareTo(w2.name);
}
};
//因为要排序的是自定义的对象,所以要给TreeSet传入比较器,要不然就会报错
Set<Worker> c= new TreeSet<>(k);
Worker w1=new Worker("cxm",23);
Worker w2=new Worker("cxk",24);
Worker w3=new Worker("cxmfe",23);
Worker w4=new Worker("cxq",45);
Worker w5=new Worker("cxu",19);
c.add(w1);
c.add(w2);
c.add(w3);
c.add(w4);
c.add(w5);
for(Worker x:c) {
System.out.println(x);
}
}
}
class Worker{
String name;
int age;
public Worker(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Worker [name=" + name + ", age=" + age + "]";
}
}
Java-SortedSet
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- org.springframework.beans.factory.UnsatisfiedDependencyEx...
- 1. 介绍 JAVA作为使用的主力语言,掌握下其历史发展也是有必要的。看看从JAVA5开始到现在的JAVA9有哪些...