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. 8086 8253 proteus仿真实验

    目录 实验内容 电路图 计数初值 关于8523的地址 关于灯的地址 代码内容 实验内容 电路图 计数初值 已知\(f_{clk0}=100khz\),所以\(T_{clk0}=\frac{1}{f_{ ...

  2. Django模板之模板变量

    深度查询句点符(.)在模板语言中有特殊的含义. 当模版系统遇到点("."),它将以这样的顺序查询: 字典查询(Dictionary lookup) 属性或方法查询(Attribut ...

  3. adb常用命令食用方法

    一.什么是adb? adb是Android Debug Bridge的缩写,即安卓调试桥:那什么是安卓调试桥?简单来说,就是一个通用命令行工具,允许计算机与模拟器或连接的安卓设备之间进行通信,提供各种 ...

  4. 走迷宫(二):在XX限制条件下,是否走得出

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1728 解题方法:BFS+访问数组vis[][]; 给你起点位置和终点位置,让你判断能不能到达,并且拐弯 ...

  5. Web前端:1、HTML&CSS概述及结构

    万维网联盟(World Wide Web Consortium)简称W3C,专门为了定义网页相关的标准而成立,如网页中的HTML.CSS.DOM.HTTP.XML等标准. 根据W3C标准,一个网页主要 ...

  6. 5.CSS的引入方式

    CSS的三种样式表 按照CSS样式书写的位置(或者引入的方式),CSS的样式表可以分为三大类: 1.行内样式表(行内式) <div style="color:red: font-siz ...

  7. Python连接不上SQL Server的两种根治思路

    连接不上数据库,首先可以排除是代码的问题,连接方式都是千篇一律的. 大多数问题都是本机的两个原因造成的,1.服务没有开启,2.没有启动SQL配置的TCP/IP 下面给出统一解决方案: 首先从开始菜单找 ...

  8. Java中的集合(三)继承Collection的Queue接口

    Java中的集合(三)继承Collection的Queue接口 一.Queue介绍 Queue接口继承自Collection接口,是Java中定义的一种队列数据结构,元素是有序的(按插入顺序排序),先 ...

  9. python爬取王者荣耀全英雄皮肤

    import os import requests url = 'https://pvp.qq.com/web201605/js/herolist.json' herolist = requests. ...

  10. & 异步使用场景

    异步的使用场景: 1.不涉及共享资源,或对共享资源只读,即非互斥操作 2.没有时序上的严格关系 3.不需要原子操作,或可以通过其他方式控制原子性 4.常用于IO操作等耗时操作,因为比较影响客户体验和使 ...