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. 8-15 Shuffle uva12174

    题意: 你正在使用的音乐播放器有一个所谓的乱序功能,即随机打乱歌曲的播放顺序.假设一共有s首歌,则一开始会给这s首歌随机排序,全部播放完毕后再重新随机排序.继续播放,依此类推.注意,当s首歌播放完毕之 ...

  2. 32:从1到n整数中1出现的次数

    import java.util.Arrays; /** * 面试题32:从1到n整数中1出现的次数 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数? * 为此他特别数了 ...

  3. My blog in AI ---神经网络,网络架构

    上一篇博文中,我们介绍了神经网络中的神经元,那么该如何组织起来这些神经元,才能发挥出最好的效果去解决现实中的问题呢? 这是一个复杂的问题,在工程中,神经网络的架构也是训练的也是一种超参数,本节先在理论 ...

  4. 【原创】获取MySQL crash 时的core file

    最近有台服务器的MySQL经常crash,为了进一步定位问题,开启了mysql core file功能,开启步骤如下,供参考 [开启步骤] 1. my.cnf文件中增加2个配置选项 [mysqld] ...

  5. iOS 11开发教程(八)定制iOS11应用程序图标

    iOS 11开发教程(八)定制iOS11应用程序图标 在图1.9中可以看到应用程序的图标是网状白色图像,它是iOS模拟器上的应用程序默认的图标.这个图标是可以进行改变的.以下就来实现在iOS模拟器上将 ...

  6. python中的super( test, self).__init__()

    python中的super( test, self).__init__() 对继承自父类的属性进行初始化 首先找到test的父类(比如是类A),然后把类test的对象self转换为类A的对象,然后“被 ...

  7. Vue methods和computed

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  8. 【BZOJ 2318】 2318: Spoj4060 game with probability Problem(概率DP)

    2318: Spoj4060 game with probability Problem Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 371  Sol ...

  9. hdu 5248 贪心

    题意:

  10. UVA 11945 Financial Management 水题

    Financial Management Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 acm.hust.edu.cn/vjudge/problem/vis ...