1. Comparator 和 Comparable 同样的地方

他们都是java的一个接口, 而且是用来对自己定义的class比較大小的,

什么是自己定义class: 如 public class Person{ String name; int age }.

当我们有这么一个personList,里面包括了person1, person2, persion3....., 我们用Collections.sort( personList ), 是得不到预期的结果的. 这时肯定有人要问, 那为什么能够排序一个字符串list呢:

如 StringList{"hello1" , "hello3" , "hello2"}, Collections.sort( stringList ) 能够得到正确的排序, 那是由于 String 这个对象已经帮我们实现了 Comparable接口 , 所以我们的 Person 假设想排序, 也要实现一个比較器。
   
2. Comparator 和 Comparable 的差别 Comparable Comparable 定义在 Person类的内部: public class Persion implements Comparable {..比較Person的大小..},  由于已经实现了比較器,那么我们的Person如今是一个能够比較大小的对象了,它的比較功能和String全然一样,能够随时随地的拿来比較大小,由于Person如今自身就是有大小之分的。 Collections.sort(personList)能够得到正确的结果。 Comparator Comparator 是定义在Person的外部的, 此时我们的Person类的结构不须要有不论什么变化,如 public class Person{ String name; int age }, 然后我们另外定义一个比較器: public PersonComparator implements Comparator() {..比較Person的大小..}, 在PersonComparator里面实现了怎么比較两个Person的大小. 所以,用这样的方法,当我们要对一个 personList进行排序的时候, 我们除了了要传递personList过去, 还须要把PersonComparator传递过去,由于怎么比較Person的大小是在PersonComparator里面实现的, 如: Collections.sort( personList , new PersonComparator() ). 3. Comparator 和 Comparable 的实例 Comparable: 实现Comparable接口要覆盖s=17470874779923938404&entry=1&q=compareTo" class="bdcs-inlinelink" target="_blank">compareTo方法, 在compareTo方法里面实现比較:
public class Person implements Comparable {
     String name;
     int age
     public int compareTo(Person another) {
          int i = 0;
          i = name.compareTo(another.name); // 使用字符串的比較
          if(i == 0) { // 假设名字一样,比較年龄, 返回比較年龄结果
               return age - another.age;
          } else {
               return i; // 名字不一样, 返回比較名字的结果.
          }
     }
}
   这时我们能够直接用 Collections.sort( personList ) 对其排序了. Comparator: 实现Comparator须要覆盖 compare 方法:
public class Person{
     String name;
     int age
} class PersonComparator implements Comparator { 
     public int compare(Person one, Person another) {
          int i = 0;
          i = one.name.compareTo(another.name); // 使用字符串的比較
          if(i == 0) { // 假设名字一样,比較年龄,返回比較年龄结果
               return one.age - another.age;
          } else {
               return i; // 名字不一样, 返回比較名字的结果.
          }
     }
}
   Collections.sort( personList , new PersonComparator()) 能够对其排序  4:总结 两种方法各有优劣, 用Comparable 简单, 仅仅要实现Comparable 接口的对象直接就成为一个能够比較的对象,可是须要改动源码, 用Comparator 的优点是不须要改动源码, 而是另外实现一个比較器, 当某个自己定义的对象须要作比較的时候,把比較器和对象一起传递过去就能够比大小了, 而且在Comparator 里面用户能够自己实现复杂的能够通用的逻辑,使其能够匹配一些比較简单的对象,那样就能够节省非常多反复劳动了。

comparator接口与Comparable接口的差别的更多相关文章

  1. Java中Comparator接口和Comparable接口的使用

    普通情况下在实现对对象元素的数组或集合进行排序的时候会用到Comparator和Comparable接口,通过在元素所在的类中实现这两个接口中的一个.然后对数组或集合调用Arrays.sort或者Co ...

  2. comparator接口与Comparable接口的区别

    1. Comparator 和 Comparable 相同的地方 他们都是java的一个接口, 并且是用来对自定义的class比较大小的, 什么是自定义class: 如 public class Pe ...

  3. 关于comparator接口和comparable接口以及它们各自的方法compare()和compareTo()

    在今天做的LeetCode的题中有两道都出现了利用接口实现对象的排序.两题的相关链接: 1.利用comparable接口对对象排序 2.利用comparator接口实现排序 因为之前都没接触过这两个接 ...

  4. Java Comparator方法 和 Comparable接口

    默认的排序方法: 让类继承Comparable接口,重写compareTo方法. 示例代码: package com.imooc.collection; import java.util.HashSe ...

  5. Java 之 比较器( Comparator接口与 Comparable 接口)

    一.定制排序:java.util.Comparator 接口 强行对某个对象 collection 进行整体排序 的比较函数.可以将 Comparator 传递给 sort 方法(如 Collecti ...

  6. 实现Comparator接口和Comparable接口,以及Map按value排序 ,map遍历

    继承Comparator接口,重写compare()方法 import java.util.ArrayList; import java.util.Arrays; import java.util.C ...

  7. Java集合中Comparator和Comparable接口的使用

    在Java集合中,如果要比较引用类型泛型的List,我们使用Comparator和Comparable两个接口. Comparable接口 -- 默认比较规则,可比较的 实现该接口表示:这个类的实例可 ...

  8. Java中 Comparator接口 与Comparable 的区别

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt159 comparator接口与Comparable接口的区别 1. Com ...

  9. Comparable 接口与Comparator的使用的对比

    package com.yhqtv.java; import org.junit.Test; import java.util.Arrays; import java.util.Comparator; ...

随机推荐

  1. [Python] Manipulate Data with Dictionaries in Python

    Dictionaries may be familiar to you as hash maps. In this lesson, you will learn how to create them, ...

  2. Appium Android Bootstrap源代码分析之启动执行

    通过前面的两篇文章<Appium Android Bootstrap源代码分析之控件AndroidElement>和<Appium Android Bootstrap源代码分析之命令 ...

  3. js---13 this call apply

    //this:this可以写在js全剧环境中(全局环境中this是window对象),this可以写在函数中,可以写在对象中, function f(){ this.name = "asdf ...

  4. Linux下ping命令、traceroute命令、tracert命令的使用

    Linux系统的ping命令是常用的网络命令,它通常用来测试与目标主机的连通性,我们经常会说“ping一下某机器,看是不是开着”.不能打开网页时会说“你先ping网关地址192.168.1.1试试”. ...

  5. Onvif开发之客户端鉴权获取参数篇

    前面一篇已经介绍了客户端如何发些设备,下面这篇简单介绍下在发现设备后,如何通过ONVIF协议来获取设备的相关参数 ONVIF中不管是客户端还是设备端,最先实现的接口都是关于能力的那个接口,在客户端实现 ...

  6. 10.cocos2d坐标系

    一.笛卡儿坐标系 OpenGl坐标系为笛卡儿右手系.x向右,y向上,z向外.在cocos2d-lua中坐标系原点在屏幕的左下角,x向右,y向上,z则是指的zorder(层级). 二.世界坐标系,本地坐 ...

  7. Java反射之getInterfaces()方法

    今天学习Spring3框架,在理解模拟实现Spring Ioc容器的时候遇到了getInterfaces()方法.getInterfaces()方法和Java的反射机制有关.它能够获得这个对象所实现的 ...

  8. Font-Awesome最新版完整使用教程

    何为Font-Awesome Font Awesome gives you scalable vector icons that can instantly be customized - size, ...

  9. android 自己定义状态栏和导航栏分析与实现

    效果 android 4.4之后,系统是支持自己定义状态栏和导航栏的.举个最典型的样例就是bilibiliclient了(iOS版本号和android版本号能用两套全然不一样符合各自系统的设计ui,良 ...

  10. AngularJS渲染性能分析

    作者:Jiang, Jilin AngularJS中,通过数据绑定.能够十分方便的构建页面.可是当面对复杂的循环嵌套结构时,渲染会遇到性能瓶颈.今天,我们将通过一些列实验,来測试AngularJS的渲 ...