import java.util.*;

public class Person implements Comparable<Person>//使Person的属性具有比较性

{

private String name;

private int age;

public Person(String name,int age)//初始化构造函数

{

this.name = name;

this.age = age;

}

public void set(String name,int age)//重新设置姓名和年龄

{

this.name = name;

this.age = age;

}

public String getName()//获取姓名

{

return name;

}

public int getAge()//获取年龄

{

return age;

}

public String toString()//将姓名和年龄以字符串的形式返回

{

return name+","+age;

}

//出现重名时,再找到另一个hash地址用来存储数据(底层自动调用)

public int hashCode()

{

return name.hashCode()+age*34;

}

//判断接受的类是不是Person类,不是就抛出异常(底层自动调用)

public boolean equals(Object obj)

{

if(!(obj instanceof Person))

throw new ClassCastException("不是Person类");

Person p = (Person)obj;

return this.name.equals(p.name) && this.age==p.age;

}

public int compareTo(Person p)//(按照自己的要求去作比较)

{

int num=new Integer(this.age).compareTo(p.age);

return num==0?this.name.compareTo(p.name):num;

}

}

public class Test

{

public static <T>void sop(T t) //使用泛型接收参数

{

System.out.println(t);

}

public static void main(String args[]) throws Exception

{

//创建一个map集合,用来存储数据  <>表示接收的是泛型,即指定的类型

TreeMap<Person,String> map = new TreeMap<Person,String>(/*new Mycompare()*/); //也可以使用这个被注释掉的自定义的比较器

//往集合添加数据

map.put(new Person("czhangsan1",11),"beijing");

map.put(new Person("zhangsan5",15),"nanjing");

map.put(new Person("azhangsan5",10),"shanghai");

map.put(new Person("zhangsan2",20),"haierbing");

map.put(new Person("bzhangsan2",20),"beijing");

map.put(new Person("zhangsan3",12),"shanghai");

map.put(new Person("zhangsan4",19),"changchun");

map.put(new Person("zhangsan4",10),"changchun");

map.put(new Person("zhangsan4",10),"zhengzhou");

//将map集合转换为set集合,因为map集合没有迭代器  ,而set集合有

Set<Map.Entry<Person,String>> entryset = map.entrySet();

//获取迭代器

Iterator<Map.Entry<Person,String>> it = entryset.iterator();

//用迭代器取数据

while(it.hasNext())

{

Map.Entry<Person,String> m = it.next();

Person key = m.getKey();//取出键

String value =m.getValue();//取出值

sop(key+"......."+"adress:"+value);//打印键和值

}

}

}

class Mycompare implements comparator<Perosn>//自定义一个比较器

{

public int compare(Person p1,Person p2)

{

int num = p1.getName().compareTo(p2.getName());

return num==0?new Integer(p1.getAge()).compareTo(new Integer(p2.getAge())):num;

}

}

//注意:上面的两种形式都实现了比较,任选其中一种就可以。要么实现comparable接口;要么在集合中传入自定义的比较器。

java://Comparator、Comparable的用法(按照要求将map集合的键值对进行顺序输出)的更多相关文章

  1. Java://Comparator、Comparable的用法(按照要求将set集合的数据进行排序输出):

    import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; //comparator. ...

  2. 【Java必修课】通过Value获取Map中的键值Key的四种方法

    1 简介 我们都知道Map是存放键值对<Key,Value>的容器,知道了Key值,使用方法Map.get(key)能快速获取Value值.然而,有的时候我们需要反过来获取,知道Value ...

  3. Java分享笔记:使用entrySet方法获取Map集合中的元素

    /*--------------------------------- 使用entrySet方法取出Map集合中的元素: ....该方法是将Map集合中key与value的关系存入到了Set集合中,这 ...

  4. Java分享笔记:使用keySet方法获取Map集合中的元素

    /*--------------------------- Map集合中利用keySet方法获取所有的元素值: ....keySet方法:将Map中的所有key值存入到Set集合中, ....利用Se ...

  5. LeetCode 677. Map Sum Pairs 键值映射(C++/Java)

    题目: Implement a MapSum class with insert, and sum methods. For the method insert, you'll be given a ...

  6. JAVA Comparator 接口排序用法

    java的比较器有两类,分别是Comparable接口和Comparator接口. 在为对象数组进行排序时,比较器的作用非常明显,首先来讲解Comparable接口. 让需要进行排序的对象实现Comp ...

  7. Java程序斗地主发牌代码,List、Map集合的应用

    Java集合存储的灵活运用List集合存储 54个编号 Map <key,value> key 对应的是编号 , value 是 牌的花色(红方梅黑)+ 具体的一张牌 ,比如 黑桃2 用2 ...

  8. Java——删除Map集合中key-value值

    通过迭代器删除Map集合中的key-value值 Iterator<String> iter = map.keySet().iterator(); while(iter.hasNext() ...

  9. java学习笔记—集合之Map集合

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: center; font: 12.0px Times } p.p2 { margin: 0.0p ...

随机推荐

  1. AngularJS HTML DOM

    AngularJS 为 HTML DOM 元素的属性提供了绑定应用数据的指令. ng-disabled 指令: ng-disabled 指令直接绑定应用程序数据到 HTML 的 disabled 属性 ...

  2. UVA 11464 暴力+位运算 ***

    题意:给你一个 n * n 的 01 矩阵,现在你的任务是将这个矩阵中尽量少的 0 转化为 1 ,使得每个数的上下左右四个相邻的数加起来是偶数.求最少的转化个数. 新风格代码 lrj书上说的很清楚了, ...

  3. JAVA基础再回首

    http://blog.csdn.net/m366917/article/details/51559031

  4. MongoDB学习笔记(1):MongoDB简介

    1. MongoDB的特点: (1) 易于使用 MongoDB是一个面向文档的数据库,非关系型数据库.通过在文档中嵌入式文档和数据,面向对象的方法能够仅使用一条记录来表现复杂的层次关系.文档的键和值不 ...

  5. Go语言 模板的使用(二)

    判断 {{if .Attended}} 如果Attended是true的话,这句是第二行 {{else}} 如果Attended是false的话,这句是第二行 {{end}} 循环 我们可以使用ran ...

  6. CodeChef COUNTARI Arithmetic Progressions(分块 + FFT)

    题目 Source http://vjudge.net/problem/142058 Description Given N integers A1, A2, …. AN, Dexter wants ...

  7. 怎样看懂Oracle的执行计划

    怎样看懂Oracle的执行计划 一.什么是执行计划 An explain plan is a representation of the access path that is taken when ...

  8. SpringMVC注解@RequestMapping全面解析---打酱油的日子

    @RequestMapping 可以出现在类级别上,也可以出现在方法上.如果出现在类级别上,那请求的 url 为 类级别上的@RequestMapping + 方法级别上的 @RequestMappi ...

  9. css 选择器优先级

    优先级自上而下逐渐递减 1. 在属性后面使用 !important 会覆盖页面内任何位置定义的元素样式. 2.作为style属性写在元素内的样式 3.id选择器 4.类选择器 5.标签选择器 6.通配 ...

  10. BZOJ4563: [Haoi2016]放棋子

    Description 给你一个N*N的矩阵,每行有一个障碍,数据保证任意两个障碍不在同一行,任意两个障碍不在同一列,要求你在 这个矩阵上放N枚棋子(障碍的位置不能放棋子),要求你放N个棋子也满足每行 ...