import java.util.ArrayList;

import java.util.Collections;

import java.util.Comparator;

//comparator、comparable的用法(按照要求将map集合的键值对进行顺序输出)

import java.util.List;

public class Test

{

   public static <T> void sop(T t)

   {

    System.out.println(t);

   }

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

   {

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

    List<Person> list = new ArrayList<Person>();

    // 往集合添加数据

    list.add(new Person("czhangsan1", "11", "beijing"));

    list.add(new Person("zhangsan5", "15", "nanjing"));

    list.add(new Person("azhangsan5", "10", "shanghai"));

    list.add(new Person("zhangsan2", "20", "haierbing"));

    list.add(new Person("bzhangsan2", "20", "beijing"));

    list.add(new Person("zhangsan3", "12", "shanghai"));

    list.add(new Person("zhangsan4", "19", "changchun"));

    list.add(new Person("zhangsan4", "10", "changchun"));

    list.add(new Person("zhangsan4", "10", "zhengzhou"));

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

    Collections.sort(list);

    System.out.println("按年龄排序:");

    for (Person person : list)

    {

    System.out.println(person.toString());

    }

    Collections.sort(list, new MyCompare());

    System.out.println("按姓名排序:");

    for (Person person : list)

    {

        System.out.println(person.toString());

    }

  }

}

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

{

   private String name;

   private String age;

   private String address;

   public Person(String name, String age, String address)// 初始化

   {

    this.name = name;

    this.age = age;

    this.address = address;

   }

   public String getName()

   {

    return name;

   }

   public void setName(String name)

   {

    this.name = name;

   }

   public String getAge()

   {

    return age;

   }

   public void setAge(String age)

   {

    this.age = age;

   }

   public String getAddress()

   {

    return address;

   }

   public void setAddress(String address)

   {

    this.address = address;

   }

   @Override

   public String toString() 

   {

    return "姓名:" + name + ", 年龄:" + age + ", 地址:" + address;

   }

   // 按年龄大小排序规则

   @Override

   public int compareTo(Person o)

   {

    return this.age.compareTo(o.getAge());

   }

}

// 按姓名字典顺序排序

class MyCompare implements Comparator<Person>// 自定义一个比较器

{

   @Override

   public int compare(Person o1, Person o2)

   {

    return o1.getName().compareTo(o2.getName());

   }

}

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

Java://Comparator、Comparable的用法(按照要求将set集合的数据进行排序输出):的更多相关文章

  1. java://Comparator、Comparable的用法(按照要求将map集合的键值对进行顺序输出)

    import java.util.*; public class Person implements Comparable<Person>//使Person的属性具有比较性 { priva ...

  2. Java中Comparable和Comparator接口区别分析

    Java中Comparable和Comparator接口区别分析 来源:码农网 | 时间:2015-03-16 10:25:20 | 阅读数:8902 [导读] 本文要来详细分析一下Java中Comp ...

  3. Java 中 Comparable 和 Comparator 比较

    Java 中 Comparable 和 Comparator 比较 目录: Comparable Comparator Comparable 和 Comparator比较 第二个例子 之 Compar ...

  4. Java之Comparable接口和Comparator接口

    Comparable & Comparator 都是用来实现集合中元素的比较.排序的: Comparable 是在集合内部定义的方法实现的排序: Comparator 是在集合外部实现的排序: ...

  5. Java 中 Comparable 和 Comparator 比较(转)

    转自http://www.cnblogs.com/skywang12345/p/3324788.html 本文,先介绍Comparable 和Comparator两个接口,以及它们的差异:接着,通过示 ...

  6. Java.lang.Comparable接口和Java.util.Comparator接口的区别

    Java的Comparator和Comparable当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comparator或Comparable,以简单的方式实现对象排序或自定义排序. 1.Com ...

  7. 【Java】Comparable和Comparator接口的区别

    Java提供了只包含一个compareTo()方法的Comparable接口.这个方法可以个给两个对象排序.具体来说,它返回负数,0,正数来表明已经存在的对象小于,等于,大于输入对象. Java提供了 ...

  8. java实现Comparable接口和Comparator接口,并重写compareTo方法和compare方法

    原文地址https://segmentfault.com/a/1190000005738975 实体类:java.lang.Comparable(接口) + comareTo(重写方法),业务排序类 ...

  9. java容器---Comparable & Comparator

    1.接口Comparable<T> API    参数类型:T ---可以与此对象进行比较的那些对象的类型 此接口强行对实现它的每个类的对象进行整体排序.这种排序被称为类的自然排序,类的c ...

随机推荐

  1. jenkins远程连接linux配置测试

    由于配置原因造成一下错误错误: jenkins.plugins.publish_over.BapPublisherException: Failed to connect session for co ...

  2. 8-12 Erratic Expansion uva12627

    题意:一开始有一个红气球  每小时后一个红气球会变成三个红气球和一个蓝气球  第k小时 a到b行之间有几个红气球 递归找规律题目 一定要注意涉及指数的时候一定要开long long 数组!!!! #i ...

  3. 2018年全国多校算法寒假训练营练习比赛(第二场)F - 德玛西亚万岁

    链接:https://www.nowcoder.com/acm/contest/74/F来源:牛客网 题目描述 德玛西亚是一个实力雄厚.奉公守法的国家,有着功勋卓著的光荣军史. 这里非常重视正义.荣耀 ...

  4. js包

    1.base.js /*语法: $("选择器") 工厂函数 */       /*寻找页面中name属性值是haha的元素*/   $("[name='haha']&qu ...

  5. ONVIF开发实例

    <开发过过程中的经验总结> ➤工具的使用     (1)首先将文件soapClientLib.c 中"代码"的第二行和第三行注释掉,实际上该文件根本没有用,为了保险起见 ...

  6. 神经网络与BP神经网络

    一.神经元 神经元模型是一个包含输入,输出与计算功能的模型.(多个输入对应一个输出) 一个神经网络的训练算法就是让权重(通常用w表示)的值调整到最佳,以使得整个网络的预测效果最好. 事实上,在神经网络 ...

  7. python装饰器原理

    妙处在于装饰器的两个return 1.装饰器 # 使用闭包 def wrap(fun): def check(): print("正在检查用户权限!") fun() return ...

  8. SLF4J versions 1.4.0 and later requires log4j 1.2.12 or later 终极解决

    http://blog.sina.com.cn/s/blog_54eb26870100uynj.html 到SLF4J官方网站:http://www.slf4j.org/codes.html#log4 ...

  9. 【转载】HTTP/FTP客户端开发库:libwww、libcurl、libfetch

    网页抓取和ftp访问是目前很常见的一个应用需要,无论是搜索引擎的爬虫,分析程序,资源获取程序,WebService等等都是需 要的,自己开发抓取库当然是最好了,不过开发需要时间和周期,使用现有的Ope ...

  10. hdoj 5122 K.Bro Sorting 贪心

    K.Bro Sorting Time Limit: 2000/2000 MS (Java/Others) Memory Limit: 512000/512000 K (Java/Others) Tot ...