Collections对List集合中的数据进行排序

有时候需要对集合中的元素按照一定的规则进行排序,这就需要用到
Java中提供的对集合进行操作的工具类Collections,其中的sort方法

 1 package com.kaishengit;
2
3 import java.util.Arrays;
4 import java.util.Collections;
5 import java.util.List;
6 /**
7 * @author Wgs
8 * @version 1.0
9 * @create:2018/04/28
10 */
11 public class SortDemo {
12 public static void main(String[] args) {
13 List<Integer> srs = Arrays.asList(5,2,9,3,4);
14 System.out.println("----排序前----");
15 // 5 2 9 3 4
16 prints(srs);
17 // 排序
18 Collections.sort(srs);
19 System.out.println("----排序后----");
20 // 2 3 4 5 9
21 prints(srs);
22 }
23
24 private static void prints(List<Integer> srs) {
25 for (Integer s : srs){
26 System.out.println(s);
27 }
28 }
29 }

结果

56,34
23,55
23,67
26,78


稍微复杂的List里面放一个复杂的对象
 1 package com.kaishengit;
2
3 import java.util.ArrayList;
4 import java.util.Collections;
5 import java.util.List;
6
7 /**
8 * @author Wgs
9 * @version 1.0
10 * @create:2018/04/28
11 */
12 public class User implements Comparable<User> {
13 private int age;
14 private int score;
15
16 public User(int age, int score) {
17 this.age = age;
18 this.score = score;
19 }
20
21 public int getAge() {
22 return age;
23 }
24
25 public void setAge(int age) {
26 this.age = age;
27 }
28
29 public int getScore() {
30 return score;
31 }
32
33 public void setScore(int score) {
34 this.score = score;
35 }
36
37 @Override
38 public int compareTo(User o) {
39 // 先按照年龄排序
40 int i = this.getAge() - o.age;
41 // 年龄相等按照成绩排序
42 if (i == 0) {
43 i = this.getScore() - o.getScore();
44 }
45 return i;
46 }
47
48 public static void main(String[] args) {
49 List<User> users = new ArrayList<User>();
50 users.add(new User(78, 26));
51 users.add(new User(67, 23));
52 users.add(new User(34, 56));
53 users.add(new User(55, 23));
54 Collections.sort(users);
55 for (User user : users) {
56 System.out.println(user.getScore() + "," + user.getAge());
57 }
58
59 /**
60 * 56,34
61 * 23,55
62 * 23,67
63 * 26,78
64 */
65 }
66 }
我们会发现sort(List<T>)方法中List中的T必须实现Comparable<T>接口,然后实现compareTo()方法,该方法的返回值0代表相等,1表示大于,-1表示小于;为什么在简单例子中没有看到实现Comparable接口呢?是因为Integer类其实自己已经实现了Comparable接口,Java已经给我们做好了。
Collections提供的第二种排序方法sort(List<T> list, Comparator<? super T> c)
 1 package com.kaishengit;
2
3 import java.util.ArrayList;
4 import java.util.Collections;
5 import java.util.Comparator;
6 import java.util.List;
7
8 /**
9 * @author Wgs
10 * @version 1.0
11 * @create:2018/04/28
12 */
13 public class User {
14 private int age;
15 private int score;
16
17 public User(int age, int score) {
18 this.age = age;
19 this.score = score;
20 }
21
22 public int getAge() {
23 return age;
24 }
25
26 public void setAge(int age) {
27 this.age = age;
28 }
29
30 public int getScore() {
31 return score;
32 }
33
34 public void setScore(int score) {
35 this.score = score;
36 }
37
38
39 public static void main(String[] args) {
40 List<User> users = new ArrayList<User>();
41 users.add(new User(78, 26));
42 users.add(new User(67, 23));
43 users.add(new User(34, 56));
44 users.add(new User(55, 23));
45 Collections.sort(users, new Comparator<User>() {
46 @Override
47 public int compare(User o1, User o2) {
48 int i = o1.getScore() - o2.getScore();
49 if(i == 0){
50 return o1.getAge() - o2.getAge();
51 }
52 return i;
53 }
54 });
55 for (User user : users) {
56 System.out.println(user.getScore() + "," + user.getAge());
57 }
58
59 /**
60 * 56,34
61 * 23,55
62 * 23,67
63 * 26,78
64 */
65 }
66 }

从上面的例子我们可以看出Students类没有实现Comparable<T>接口,只是在sort()方法
中多传入一个参数,只不过该参数是一个接口我们需要实现其compare方法。

List集合中的元素进行排序的更多相关文章

  1. java如何对List集合中的元素进行排序(请收藏)

    在java开发中有时候我们需要对List集合中的元素按照一定的规则进行排序,比如说有个Person的集合,我们要根据Person的age属性进行排序输出,这就需要用到Java中提供的对集合进行操作的工 ...

  2. 2018.9.17 面试问题-----如何对List集合中的元素进行排序?

    Collections对List集合中的数据进行排序 有时候需要对集合中的元素按照一定的规则进行排序,这就需要用到 Java中提供的对集合进行操作的工具类Collections,其中的sort方法 先 ...

  3. 对List集合中的元素进行排序

    原文:http://blog.csdn.net/veryisjava/article/details/51675036 Collections对List集合中的数据进行排序 有时候需要对集合中的元素按 ...

  4. c#---部分;把数组或者结构体存入集合里,然后再从集合中取出之后,输出;foreach既可以用到提取数组重点额数据,也可以提取集合中的数据(前提是集合中的元素是相同数据类型)

    1.输入班级人数,统计每个人的姓名,性别,年龄:集合与数组 //Console.Write("请输入班级人数:"); //int a = int.Parse(Console.Rea ...

  5. 对list集合中的对象进行排序(转载)

    原文链接:http://blog.csdn.net/veryisjava/article/details/51675036 Collections对List集合中的数据进行排序 有时候需要对集合中的元 ...

  6. 谷歌笔试题--给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数。

    谷歌笔试题--给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数. Google2009华南地 ...

  7. java中对List中的元素进行排序

    Collections对List集合中的数据进行排序 有时候需要对集合中的元素按照一定的规则进行排序,这就需要用到 Java中提供的对集合进行操作的工具类Collections,其中的sort方法 N ...

  8. 巧妙利用ToArray()函数移除集合中的元素

    当我们对集合foreach遍历时,不能直接移除遍历的集合的元素,解决的方法有很多种,见我之前的随笔: http://www.cnblogs.com/527289276qq/p/4331000.html ...

  9. list,set等集合遍历时,不能remove集合中的元素。需要new一个Object或者list,set,里面add需要删除的元素,等集合遍历完了进行remove(Object)或者removeAll(list/set)操作

    list,set等集合遍历时,不能remove集合中的元素.需要new一个Object或者list,set,里面add需要删除的元素,等集合遍历完了进行remove(Object)或者removeAl ...

  10. 删除 list 集合中的元素

    删除 list 集合中的元素,当删除的元素有多个的时候,只能使用迭代器来删除. 当删除 list 集合中的元素只有一个的时候,有三种方法都可以实现. import java.util.ArrayLis ...

随机推荐

  1. 一文剖析PolarDB HTAP的列存数据压缩

    简介: PolarDB MySQL是阿里云自研的云原生数据库,主要处理在线事务负载(OLTP, OnLine Transactional Processing),深受企业用户的青睐. 前言 数据库迁移 ...

  2. 一文了解阿里一站式图计算平台GraphScope

    简介: 随着大数据的爆发,图数据的应用规模不断增长,现有的图计算系统仍然存在一定的局限.阿里巴巴拥有全球最大的商品知识图谱,在丰富的图场景和真实应用的驱动下,阿里巴巴达摩院智能计算实验室研发并开源了全 ...

  3. 阿里巴巴云原生 etcd 服务集群管控优化实践

    简介: 这些年,阿里云原生 etcd 服务发生了翻天覆地的变化,这篇文章主要分享一下 etcd 服务在面对业务量大规模增长下遇到的问题以及我们是如何解决的,希望对读者了解 etcd 的使用和管控运维提 ...

  4. 贝壳基于 Flink 的实时计算演进之路

    简介: 贝壳找房在实时计算之路上的平台建设以及实时数仓应用. 摘要:贝壳找房大数据平台实时计算负责人刘力云带来的分享内容是贝壳找房的实时计算演进之路,内容如下: 发展历程 平台建设 实时数仓及其应用场 ...

  5. 2019-10-14-云之幻-UWP-视频教程

    title author date CreateTime categories 云之幻 UWP 视频教程 lindexi 2019-10-14 21:8:26 +0800 2019-10-14 21: ...

  6. github只下载某个文件或文件夹(使用GitZip插件)

    安装GitZip插件 (此安装过程需要梯子(不懂"梯子",百度一下就明白)) 1. 打开插件管理页面 方法一:打开Chrome浏览器(Edge浏览器同理),在Chrom地址栏输入c ...

  7. 《Effective C++》第三版-0. 导读(Introduction)

    目录 术语(Terminology) 命名习惯(Naming Conventions) 关于线程(Threading Consideration) TR1和Boost 术语(Terminology) ...

  8. Node.js 万字教程

    0. 基础概念 Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,使用了一个事件驱动.非阻塞式 I/O 模型,让 JavaScript 运行在服务端的开发平台. ...

  9. Docker 必知必会----初识

    什么是Docker?Docker 是一个开源的容器管理引擎.开发者可以通过Docker直接管理应用程序所需要的容器.它的logo如下: 为什么需要Docker使用Docker主要有两个原因,1.屏蔽不 ...

  10. apisix~lua插件开发与插件注册

    开发插件的步骤 在APISIX中,要自定义插件,一般需要按照以下步骤进行操作: 编写Lua脚本:首先,你需要编写Lua脚本来实现你想要的功能.可以根据APISIX提供的插件开发文档和示例进行编写. 将 ...