我们在实际的开发工作中,经常会碰到排序的问题,如题,我们如何针对List集合中的某一个属性进行排序

当list集合中的元素类型是我们自定义类型时,有两种对list中的元素进行排序的方法:

方法一

  让list集合中的元素类型,也就是我们自定义的类实现Comparable<T>接口,并在类中编写public int compareTo(T o)方法。如下所示:

 1 public class Test
2 {
3 public static void main(String[] args)
4 {
5 ArrayList<Entity> list=new ArrayList<Entity>();
6 list.add(new Entity("李四",24));
7 list.add(new Entity("张三",13));
8 list.add(new Entity("王五",25));
9 System.out.println("排序前:"+list);
10 Collections.sort(list);
11 System.out.println("排序后:"+list);
12 }
13 }
14 class Entity implements Comparable<Entity>
15 {
16 String name;
17 int age;
18 public Entity(String name, int age) {
19 super();
20 this.name = name;
21 this.age = age;
22 }
23 public String getName() {
24 return name;
25 }
26 public void setName(String name) {
27 this.name = name;
28 }
29 public int getAge() {
30 return age;
31 }
32 public void setAge(int age) {
33 this.age = age;
34 }
35 @Override
36 public String toString() {
37 return "Entity [name=" + name + ", age=" + age + "]";
38 }
39 @Override
40 public int compareTo(Entity o)
41 {
42 if(this.getAge()>o.getAge())
43 {
44 return 1;
45 }
46 else if(this.getAge()<o.getAge())
47 {
48 return -1;
49 }
50 else
51 {
52 return 0;
53 }
54 }
55 }

  我们想对Entity这个类型按照age属性值从小到大排序,则方法一是让Entity这个类实现Comparable<Entity>接口,并编写public int compareTo(Entity o) 方法。这样使用Collections.sort(list);就可以对list中的对象进行按照age大小排序。

输出结果:

排序前:[Entity [name=李四, age=24], Entity [name=张三, age=13], Entity [name=王五, age=25]]
排序后:[Entity [name=张三, age=13], Entity [name=李四, age=24], Entity [name=王五, age=25]]

方法二

  方法二就是在排序的时候,给sort()方法传入一个比较器。具体来说,就是传入一个实现比较器接口的匿名内部类,目的是告诉sort()方法,按照比较器来对list中的对象进行排序。如下所示:

 1 public class Test
2 {
3 public static void main(String[] args)
4 {
5 ArrayList<Entity> list=new ArrayList<Entity>();
6 list.add(new Entity("李四",24));
7 list.add(new Entity("张三",13));
8 list.add(new Entity("王五",25));
9 System.out.println("排序前:"+list);
10 Collections.sort(list,new Comparator<Entity>() {
11 @Override
12 public int compare(Entity o1, Entity o2)
13 {
14 if(o1.getAge()>o2.getAge())
15 {
16 return 1;
17 }
18 else if(o1.getAge()<o2.getAge())
19 {
20 return -1;
21 }
22 else
23 {
24 return 0;
25 }
26 }
27 });
28 System.out.println("排序后:"+list);
29 }
30 }
31 class Entity
32 {
33 String name;
34 int age;
35 public Entity(String name, int age) {
36 super();
37 this.name = name;
38 this.age = age;
39 }
40 public String getName() {
41 return name;
42 }
43 public void setName(String name) {
44 this.name = name;
45 }
46 public int getAge() {
47 return age;
48 }
49 public void setAge(int age) {
50 this.age = age;
51 }
52 @Override
53 public String toString() {
54 return "Entity [name=" + name + ", age=" + age + "]";
55 }
56 }

  当给sort()方法传入比较器的时候,sort()方法就会根据比较器来对list中的对象进行排序。

输出结果:

排序前:[Entity [name=李四, age=24], Entity [name=张三, age=13], Entity [name=王五, age=25]]
排序后:[Entity [name=张三, age=13], Entity [name=李四, age=24], Entity [name=王五, age=25]]

  而sort()方法为什么能对String类型的数据进行排序呢?

  答案是,String这个类实现了Comparable<String>接口。所以,可以直接用Collections.sort(list);来对String类型的数据进行排序。

最新文章

  1. java反射
  2. Javascript 编程小技巧总结(部分内容借鉴他人)
  3. 环回接口(loopback interface)的新认识
  4. 集成框架jar包的一些选择
  5. DOM对象控制HTML无素——详解3
  6. C++ 哈希表
  7. SharePoint将网站另存为模板
  8. ASP.NET MVC View向Controller提交数据
  9. sql server 表分区
  10. C# FTP操作类的代码
  11. yii2-redis 扩展详解
  12. node.js中 express + multer 处理文件上传
  13. A+ B
  14. 在html中引入css、js和jQuery的方法
  15. makefile怎么写?
  16. 【C语言】练习5-8
  17. html节点操作与事件
  18. Apache2.4使用require指令进行访问控制--允许或限制IP访问/通过User-Agent禁止不友好网络爬虫
  19. Discuz常见小问题-如何使用QQ登陆
  20. GO语言官方中文教程!

热门文章

  1. 为 MaixPy 加入软 I2C 接口(移植 MicroPython 的 I2C)
  2. Linux知识点笔记
  3. 达梦产品技术支持培训-day2-DM8常用SQL
  4. RHSA-2018:1200-重要: patch 安全更新(代码执行)
  5. docker容器命令1
  6. 【dos】wmic命令
  7. c++的一些习惯
  8. 多测师讲解selenium_alert弹框定位_高级讲师肖sir
  9. 【故障公告】博客系统升级到 .NET 5.0 引发的故障
  10. BASH提示符颜色、显示返回值,终端标题显示当前目录与正在执行的命令