Java 排序 Compare 

在Java中使用集合来存储数据时非常常见的,集合排序功能也是常用功能之一.下面看一下如何进行集合排序,常用的方法有: ComparatorComparable

Comparator接口

使用步骤:

  1. 新建比较类,
  2. 实现Comparator接口,
  3. 重写compare方法,
  1. package sort; 


  2. import java.util.Comparator; 


  3. public class LuckBoyCompare implements Comparator<LuckBoy>{ 


  4. @Override 

  5. public int compare(LuckBoy o1, LuckBoy o2) { 

  6. return o1.getAge()-o2.getAge(); 







  • 调用Collections.sort()方法进行排序,
  • 形式:Collections.sort(集合, 比较器实例).
  1. @Test 

  2. public void test1() { 

  3. List<LuckBoy> boyList = new ArrayList<LuckBoy>(); 

  4. LuckBoy boy1 = new LuckBoy("张三",13,"上海"); 

  5. LuckBoy boy2 = new LuckBoy("李四",12,"北京"); 

  6. LuckBoy boy3 = new LuckBoy("王五",18,"深圳"); 

  7. LuckBoy boy4 = new LuckBoy("马六",17,"南京"); 


  8. boyList.add(boy1); 

  9. boyList.add(boy2); 

  10. boyList.add(boy3); 

  11. boyList.add(boy4); 


  12. System.out.println("排序前:"); 

  13. for (LuckBoy luckBoy : boyList) { 

  14. System.out.println(luckBoy); 




  15. System.out.println("排序后:"); 

  16. Collections.sort(boyList, new LuckBoyCompare()); 

  17. for (LuckBoy luckBoy : boyList) { 

  18. System.out.println(luckBoy); 





LuckBoy.java

  1. package sort; 


  2. public class LuckBoy{ 

  3. private String name; 

  4. private Integer age; 

  5. private String city; 


  6. public LuckBoy() { 

  7. super(); 




  8. public LuckBoy(String name, Integer age, String city) { 

  9. super(); 

  10. this.name = name; 

  11. this.age = age; 

  12. this.city = city; 




  13. public String getName() { 

  14. return name; 



  15. public void setName(String name) { 

  16. this.name = name; 



  17. public Integer getAge() { 

  18. return age; 



  19. public void setAge(Integer age) { 

  20. this.age = age; 



  21. public String getCity() { 

  22. return city; 



  23. public void setCity(String city) { 

  24. this.city = city; 




  25. @Override 

  26. public String toString() { 

  27. return "LuckBoy [name=" + name + ", age=" + age + ", city=" + city + "]"; 





打印结果:

排序前:
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=王五, age=18, city=深圳]
LuckBoy [name=马六, age=17, city=南京]
排序后:
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=马六, age=17, city=南京]
LuckBoy [name=王五, age=18, city=深圳]

Comparable接口

使用步骤:

  • 数据模型实现Comparable接口,
  • 重写compareTo方法,
  1. package sort; 


  2. public class LuckBoy implements Comparable<LuckBoy>{ 

  3. //TODO 中间代码省略 

  4. @Override 

  5. public int compareTo(LuckBoy o) { 

  6. return this.age-o.age; 






  • 调用Collections.sort()方法进行排序,
  • 形式:Collections.sort(集合)
  1. @Test 

  2. public void test2() { 

  3. List<LuckBoy> boyList = new ArrayList<LuckBoy>(); 

  4. LuckBoy boy1 = new LuckBoy("张三",13,"上海"); 

  5. LuckBoy boy2 = new LuckBoy("李四",12,"北京"); 

  6. LuckBoy boy3 = new LuckBoy("王五",18,"深圳"); 

  7. LuckBoy boy4 = new LuckBoy("马六",17,"南京"); 


  8. boyList.add(boy1); 

  9. boyList.add(boy2); 

  10. boyList.add(boy3); 


  11. boyList.add(boy4); 


  12. System.out.println("============================"); 

  13. System.out.println("排序前:"); 

  14. for (LuckBoy luckBoy : boyList) { 

  15. System.out.println(luckBoy); 




  16. System.out.println("排序后:"); 

  17. Collections.sort(boyList); 

  18. for (LuckBoy luckBoy : boyList) { 

  19. System.out.println(luckBoy); 





打印结果:

排序前:
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=王五, age=18, city=深圳]
LuckBoy [name=马六, age=17, city=南京]
排序后:
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=马六, age=17, city=南京]
LuckBoy [name=王五, age=18, city=深圳]

区别

Comparator 使用灵活,不需要修改源码.但是,使用时需要传入比较器对象;

Comparable 使用简单,但是需要修改源码.

集合排序 Comparator和Comparable的使用区别的更多相关文章

  1. Comparator与Comparable用法与区别

    一.概述.   Comparator和Comparable两者都属于集合框架的一部分,都是用来在对象之间进行比较的,但两者又有些许的不同,我们先通过一个例子来看一下他们的区别,然后再分别学习下它们的源 ...

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

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

  3. Java自学-集合框架 Comparator和Comparable

    Java Comparator和Comparable 步骤 1 : Comparator 假设Hero有三个属性 name,hp,damage 一个集合中放存放10个Hero,通过Collection ...

  4. 集合排序Comparable和Comparator有什么区别?

    Comparable和Comparator兄弟俩长得是真像.但是,需要注意下,使用中它们还是有不少区别的.下面,就一探究竟吧. 一.Comparator 做过集合排序的童鞋应该知道,可以使用Colle ...

  5. Java集合排序方法comparable和comparator的总结

    一.概述Comparable和Comparator都是用来实现集合中元素的比较.排序的.Comparable是在集合内部定义的方法实现的排序,位于java.lang下.Comparator是在集合外部 ...

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

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

  7. Java学习笔记--集合元素的比较Comparable,Comparator

    原文见: http://www.cnblogs.com/sunflower627/p/3158042.html 1. Comparator 和 Comparable 相同的地方 他们都是java的一个 ...

  8. 接口Comparator和Comparable的区别和联系

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

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

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

随机推荐

  1. Java流程语句

    流程控制语句 if语句: if语句的执行流程 例子: public class IfDemo01 { public static void main(String[] args) { int x = ...

  2. 数据预处理:独热编码(One-Hot Encoding)

    python机器学习-sklearn挖掘乳腺癌细胞( 博主亲自录制) 网易云观看地址 https://study.163.com/course/introduction.htm?courseId=10 ...

  3. 数据库基础SQL知识面试题一

    数据库基础SQL知识面试题一 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 如标题所示,本篇博客主要介绍基础知识的面试题.大家可以用来测试面试者的技术水平,由于个人水平所限,难免 ...

  4. minio golang client使用

    初始化 var ( endpoint = "127.0.0.1:8888" accessKeyID = "YXU5IXETKKPX171K4Z6O" secre ...

  5. HanLP 关键词提取算法分析

    HanLP 关键词提取算法分析 参考论文:<TextRank: Bringing Order into Texts> TextRank算法提取关键词的Java实现 TextRank算法自动 ...

  6. HttpService

    // // Source code recreated from a .class file by IntelliJ IDEA // (powered by Fernflower decompiler ...

  7. Hyperic-Sigar简介——检测与监控

    http://blog.csdn.net/liyong199012/article/details/20302761 Hyperic-Sigar是一个收集系统各项底层信息的工具集.他有如下特点: 1. ...

  8. 执行sql,使用带参的写法

    db.ExecuteNonQuery("UPDATE QU_QUALITYREPORT SET RETOSTATUS=1 WHERE BATCHID=@0 AND  PROVINCEAREA ...

  9. Zipkin 分布式数据追踪系统

    Zipkin 是一个分布式数据追踪系统,适用于微服务架构下的调用链路数据采集及分析工作. 可通过一个 Web 前端轻松的收集和分析数据,例如用户每次请求服务的处理时间等,可方便的监测系统中存在的瓶颈. ...

  10. CF961G Partitions

    传送门 luogu 显然每个数的贡献可以一起算感性理解一下,于是答案就是权值总和乘以每个数被算了几次 那个"集合大小为\(|S|\)的集合权值为权值和乘\(|S|\)",可以看成一 ...