1、list集合中的对象实现Comparable接口

public class User implements Comparable<User>{

private Integer id;

/**
  * 用户名
  */

private String userName;

/**
  * 年龄
  */

private Integer age;

@Override

public int compareTo(User o) {
     // TODO Auto-generated method stub
     return this.age-o.age;

}

}

测试类实现list按照实体类的age字段排序

public static void main(String[] args) {
         List<User> list = Lists.newArrayList();
         User user1 = new User(23);
         User user2 = new User(2);
         User user3 = new User(43);
         list.add(user1);
         list.add(user2);
         list.add(user3);
         Collections.sort(list);
         for (User user : list) {
             System.out.println(user.getAge());
         }

}

打印结果为

2

23

43

还可以根据lsit集合中的对象的某个字段获取最大值和最小值,通过Collections.min()和Collections.max()方法

public static void main(String[] args) {
         List<User> list = Lists.newArrayList();
         User user1 = new User(23);
         User user2 = new User(2);
         User user3 = new User(43);
         list.add(user1);
         list.add(user2);
         list.add(user3);
         for (User user : list) {
             System.out.println(Collections.min(list).getAge())
         }

}

打印结果为

2

2、通过匿名内部类来进行比较排序

public static void main(String[] args) {


         List<Member> mList = Lists.newArrayList();
         Member member1 = new Member("李鸿章",4);
         Member member2 = new Member("张志红",2);
         Member member3 = new Member("张会生",3);
         mList.add(member1);
         mList.add(member3);
         mList.add(member2);
         //1、用Comparator匿名内部类来进行排序
         Collections.sort(mList, new Comparator<Member>() {
             @Override
             public int compare(Member o1, Member o2) {
                 return o1.getAge()-o2.getAge();
             }
            
         });
         for (Member member : mList) {
             System.out.println(member.getAge()+"---"+member.getNickname());
         }

}

此处为但条件排序,根据年龄进行排序,结果为

2---张志红

3---张会生

4---李鸿章

也可以按照多条件来排序,先按名称首字母排序,相同再按年龄排序

public static void main(String[] args) {
      List<Member> mList = Lists.newArrayList();
         Member member1 = new Member("李鸿章",4);
         Member member2 = new Member("张志红",2);
         Member member3 = new Member("张会生",3);
         mList.add(member1);
         mList.add(member3);
         mList.add(member2);
         //多条件排序
         Collections.sort(mList, new Comparator<Member>() {
             @Override
             public int compare(Member o1, Member o2) {
                 int rs=0;
                 int a = o1.getNickname().compareTo(o2.getNickname());
                 if(a!=0) {
                     rs= a>0?-1:2;
                 }else {
                     a=o1.getAge().compareTo(o2.getAge());
                     rs= a>0?1:-1;
                 }
                 return rs;
             }
            
         });
         for (Member member : mList) {
             System.out.println(member.getAge()+"---"+member.getNickname());
         }
     }

打印结果为

4---李鸿章

2---张志红

3---张会生

3、jdk1.8开始引入了lambda表达式,可以用来替换匿名内部类

Lambda表达式的语法
基本语法:
(parameters) -> expression

(parameters) ->{ statements; }

下面是Java lambda表达式的简单例子:

// 1. 不需要参数,返回值为 5
() -> 5 // 2. 接收一个参数(数字类型),返回其2倍的值
x -> 2 * x // 3. 接受2个参数(数字),并返回他们的差值
(x, y) -> x – y // 4. 接收2个int型整数,返回他们的和
(int x, int y) -> x + y // 5. 接受一个 string 对象,并在控制台打印,不返回任何值(看起来像是返回void)
(String s) -> System.out.print(s)

所以上面通过匿名内部类对List排序的方法就可以改写成下面的

Collections.sort(mList,(Member m1, Member m2) ->m1.getAge().compareTo(m2.getAge()));

List集合排序的方法的更多相关文章

  1. Collections -集合排序compareTo方法重写,shuffle,addall

    package cn.learn.collection.Collections; /* 排序的对象的类,实现comparable借口,重写compareto方法 若要打印必须重写toString方法, ...

  2. 关于自定义 List集合排序的方法!

    大致流程: 排序是用到排序的接口Comparator<T>你要先建一个类实现比较器Comparator //大致流程public class StuComp implements Comp ...

  3. JS 对Array集合排序的方法

    我的业务是根据距离的远近经行一个排序: 第一种方法:冒泡排序 排序前的数据是这样子的: 排序后是这样子的: 代码可以直接复制使用的: <!doctype html> <html> ...

  4. Java中List集合排序的方法 比较器的使用 根据学生对象数学 语文 英语成绩总和进行sort排序

    package com.swift; import java.util.ArrayList; import java.util.Collections; import java.util.Compar ...

  5. 【转载】 C#中List集合使用OrderByDescending方法对集合进行倒序排序

    在C#的List集合操作中,有时候需要针对List集合进行排序操作,如果是对List集合按照元素对象或者元素对象的某个属性进行倒序排序的话,可以使用OrderByDescending方法来实现,Ord ...

  6. 【Java进阶】---map集合排序

    map集合排序         这篇文章讲的不仅仅是map排序,比如把对象按某一属性排序,它都可以解决这些问题.   比如,有N个对象,每个对象有个属性就是成绩,成绩分:优秀,良好,合格.那我们如何按 ...

  7. CopyOnWriteArrayList集合排序异常问题

    1.集合自定义排序实现 对List集合的自定义排序想必大家都知道要使用如下的方式,通过实现Comparator接口并实现compare方法来实现. /** * * @方法名 changeChain * ...

  8. .Net中集合排序的一种高级玩法

    背景: 学生有名称.学号, 班级有班级名称.班级序号 学校有学校名称.学校编号(序号) 需求 现在需要对学生进行排序 第一排序逻辑 按学校编号(序号)排列 再按班级序号排列 再按学生学号排列 当然,在 ...

  9. Java集合排序及java集合类详解--(Collection, List, Set, Map)

    1         集合框架 1.1         集合框架概述 1.1.1         容器简介 到目前为止,我们已经学习了如何创建多个不同的对象,定义了这些对象以后,我们就可以利用它们来做一 ...

随机推荐

  1. ambari hdp ssh链接错误

    错误信息: ERROR 2019-09-05 10:29:05,700 NetUtil.py:96 - EOF occurred in violation of protocol (_ssl.c:57 ...

  2. 系列13 docker asp.net core部署

    一.介绍   本篇完整介绍asp.net core web api如何部署到docker容器中,并通过外部访问web api服务.在编写完成dockerfile之后,可以通过docker [image ...

  3. Vue路由的hash模式与history模式的区别?

    1.首先router有两种模式:hash模式(默认).history模式(需配置mode: 'history') hash和history的区别?   hash                    ...

  4. flask之Blueprint蓝图

    flask_Blueprint.py ''' flask中的Blueprint蓝图: (1)新建模块,例如Bp1.py,Bp2.py,在模块中创建蓝图实例 (2)通过app.register_blue ...

  5. Django之ORM执行原生sql语句

    django中的ORM提供的操作功能有限,在模型提供的查询API不能满足实际工作需要时,可以在ORM中直接执行原生sql语句. Django 提供两种方法使用原生SQL进行查询:一种是使用raw()方 ...

  6. oracle start with

    select * from t where 1=1 START WITH key_id=600 CONNECT BY PRIOR key_id = pid order by key_id desc

  7. ios审核 "prefs:root="被拒

    https://blog.csdn.net/xnickname666/article/details/83068516 使用TZImagePicker  https://github.com/banc ...

  8. js时间格式转换,传入时间戳,第二哥参数是格式,也可不传

    export function parseTime(time, pattern) { if (arguments.length === 0 || !time) { return null } cons ...

  9. C#中的any和all

    any是判断列表里面是否有哪怕一个: all是判断列表里面是否每一项都包含:

  10. Java线程的启动与中止

    一.线程与进程的关系 关于进程与线程,百度百科上是这样描述的: 进程(Process) 是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础. 在当 ...