zoukankan      html  css  js  c++  java
  • JDK1.8对List指定字段进行排序

    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Comparator;
    import java.util.List;

    import com.wubei.demo.bean.Order;


    /**
    * List根据指定字段进行排序
    *
    */
    public class ListStreamTest {

    public static void main(String[] args) {


    String orderId1 = "2321837281372913";
    String userId1 = "20180701001";
    String orderId2 = "2321837281372914";
    String userId2 = "20180701002";
    String orderId3 = "2321837281372912";
    String userId3 = "20180701003";
    String orderId4 = "2321837281372918";
    String userId4 = "20180701005";
    String orderId5 = "2321837281372918";
    String userId5 = "20180701004";

    Order order = new Order();
    order.setUserId(userId1);
    order.setOrderId(orderId1);
    Order order1 = new Order();
    order1.setOrderId(orderId2);
    order1.setUserId(userId2);

    Order order2 = new Order();
    order2.setOrderId(orderId3);
    order2.setUserId(userId3);
    Order order3 = new Order();
    order3.setOrderId(orderId4);
    order3.setUserId(userId4);
    Order order4 = new Order();
    order4.setOrderId(orderId5);
    order4.setUserId(userId5);
    List<Order> orderList = new ArrayList<Order>();
    orderList.add(order);
    orderList.add(order1);
    orderList.add(order2);
    orderList.add(order3);
    orderList.add(order4);

    //1.jdk8 lambda排序,带参数类型
    orderList.sort(( Order ord1, Order ord2) -> ord2.getOrderId().compareTo(ord1.getOrderId()));

    //2.jdk8 lambda排序,不带参数类型
    orderList.sort(( ord1, ord2) -> ord2.getOrderId().compareTo(ord1.getOrderId()));

    //3.jdk8 升序排序,Comparator提供的静态方法
    Collections.sort(orderList, Comparator.comparing(Order::getOrderId));

    //4.jdk8 降序排序,Comparator提供的静态方法
    Collections.sort(orderList, Comparator.comparing(Order::getOrderId).reversed());

    //5.jdk8 组合排序,Comparator提供的静态方法,先按orderId排序,orderId相同的按userId排序
    Collections.sort(orderList, Comparator.comparing(Order::getOrderId).reversed().thenComparing(Order::getUserId));

    orderList.stream().forEach(str -> System.out.println(str.getOrderId()+"/" + str.getUserId()));

    }
    }

  • 相关阅读:
    【转载】[C#]Log4net中的RollingFileAppender解析
    【转载】大数据量传输时配置WCF的注意事项
    Sql 数据引擎中删除用户名、密码信息
    win10 HTTP 错误 500.21
    SQL Server 将Id相同的字段合并,并且以逗号隔开
    C#中2个日期类型相减
    sql server 查询本年的每个月的数据
    sql server 查询本周、本月所有天数的数据
    sql server中的日期函数
    Sql Server 逻辑文件 '' 不是数据库 '' 的一部分。请使用 RESTORE FILELISTONLY 来列出逻辑文件名。
  • 原文地址:https://www.cnblogs.com/WAbby/p/9249833.html
Copyright © 2011-2022 走看看