TreeMap使用自定义Comparator



public class MapT {

public static void main(String[] args) {
TreeMap<Student,String> tm=new TreeMap<Student,String>(new StuNameComparator());

tm.put(new Student("黎明", 21),"北京");
tm.put(new Student("小红", 20),"上海");
tm.put(new Student("小明", 25),"武汉");
tm.put(new Student("小兰", 20),"南京");
tm.put(new Student("黎明", 21),"南京");

 Set<Map.Entry<Student,String>>  entrySet=tm.entrySet();
      Iterator<Map.Entry<Student,String>> itor=entrySet.iterator();
            while(itor.hasNext()){
            Map.Entry<Student,String> me= itor.next();
            Student stu=me.getKey();
            String addr=me.getValue();
            System.out.println(stu.toString()+"   "+addr); 
            }
}

}


//************************************************************

import java.util.Comparator;


public class StuNameComparator implements Comparator<Student>{


@Override
public int compare(Student s1, Student s2) {
// TODO Auto-generated method stub
int num=s1.getName().compareTo(s2.getName());
if(num==0){
return new Integer(s1.getAge()).compareTo(new Integer(s2.getAge()));
}

return num;
}

}

//*************************************************************



public class Student implements Comparable<Student>{
private String name;
private int age;
Student(String name,int age){
this.name=name;
this.age=age;

}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}


public int hashCode(){
return name.hashCode()+age*34;
}
public boolean equals(Object obj){
if(!(obj instanceof Student)){
throw new ClassCastException("类型不匹配");
}
Student s=(Student)obj;
return this.name.equals(s.name)&&this.age==s.age;
}


public String toString(){
return name+" :"+age;
}
@Override
public int compareTo(Student s) {
int num=new Integer(this.age).compareTo(new Integer(s.age));
if(num==0){
return this.name.compareTo(s.name);
}

return num;
}


}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ygl6150373

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值