java sorted set_Java-SortedSet

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 k = new Comparator(){

//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 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 + "]";

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值