在最先之前,我先卖个关子提一个问题:我们现在有一个Employee员工类。

@Data
@AllArgsConstructor
public class Employee {

   private Integer id;
   private Integer age;   //岁数
   private String gender;  //性别
   private String firstName;  
   private String lastName;
}

你知道怎么对一个Employee工具组成的List聚集,先根据性别字段倒序排序,再根据岁数的倒序举行排序么?若是您不知道4行代码以内的解决方案(其实是1行代码就可以实现,但笔者花样化为4行),我以为您有需要一步步的看下去。

一、字符串List排序

cities是一个字符串数组。注重london的首字母是小写的。

List<String> cities = Arrays.asList(
        "Milan",
        "london",
        "San Francisco",
        "Tokyo",
        "New Delhi"
);
System.out.println(cities);
//[Milan, london, San Francisco, Tokyo, New Delhi]

cities.sort(String.CASE_INSENSITIVE_ORDER);
System.out.println(cities);
//[london, Milan, New Delhi, San Francisco, Tokyo]

cities.sort(Comparator.naturalOrder());
System.out.println(cities);
//[Milan, New Delhi, San Francisco, Tokyo, london]
  • 当使用sort方式,根据String.CASE_INSENSITIVE_ORDER(字母大小写不敏感)的规则排序,效果是:[london, Milan, New Delhi, San Francisco, Tokyo]
  • 若是使用Comparator.naturalOrder()字母自然顺序排序,效果是:[Milan, New Delhi, San Francisco, Tokyo, london]

同样我们可以把排序器Comparator用在Stream管道流中。

cities.stream().sorted(Comparator.naturalOrder()).forEach(System.out::println);

//Milan
//New Delhi
//San Francisco
//Tokyo
//london

在java 7我们是使用Collections.sort()接受一个数组参数,对数组举行排序。在java 8之后可以直接挪用聚集类的sort()方式举行排序。sort()方式的参数是一个对照器Comparator接口的实现类,Comparator接口的我们下一节再给人人先容一下。

二、整数类型List排序

List<Integer> numbers = Arrays.asList(6, 2, 1, 4, 9);
System.out.println(numbers); //[6, 2, 1, 4, 9]

numbers.sort(Comparator.naturalOrder());  //自然排序
System.out.println(numbers); //[1, 2, 4, 6, 9]

numbers.sort(Comparator.reverseOrder()); //倒序排序
System.out.println(numbers);  //[9, 6, 4, 2, 1]

三、按工具字段对List<Object>排序

这个功效就对照有意思了,举个例子人人明白一下。

Employee e1 = new Employee(1,23,"M","Rick","Beethovan");
Employee e2 = new Employee(2,13,"F","Martina","Hengis");
Employee e3 = new Employee(3,43,"M","Ricky","Martin");
Employee e4 = new Employee(4,26,"M","Jon","Lowman");
Employee e5 = new Employee(5,19,"F","Cristine","Maria");
Employee e6 = new Employee(6,15,"M","David","Feezor");
Employee e7 = new Employee(7,68,"F","Melissa","Roy");
Employee e8 = new Employee(8,79,"M","Alex","Gussin");
Employee e9 = new Employee(9,15,"F","Neetu","Singh");
Employee e10 = new Employee(10,45,"M","Naveen","Jain");


List<Employee> employees = Arrays.asList(e1, e2, e3, e4, e5, e6, e7, e8, e9, e10);

employees.sort(Comparator.comparing(Employee::getAge));
employees.forEach(System.out::println);
  • 首先,我们创建了10个Employee工具,然后将它们转换为List
  • 然后重点的的代码:使用了函数应用Employee::getAge作为工具的排序字段,即使用员工的岁数作为排序字段
  • 然后挪用List的forEach方式将List排序效果打印出来,如下(固然我们重写了Employee的toString方式,否则打印效果没有意义):
Employee(id=2, age=13, gender=F, firstName=Martina, lastName=Hengis)
Employee(id=6, age=15, gender=M, firstName=David, lastName=Feezor)
Employee(id=9, age=15, gender=F, firstName=Neetu, lastName=Singh)
Employee(id=5, age=19, gender=F, firstName=Cristine, lastName=Maria)
Employee(id=1, age=23, gender=M, firstName=Rick, lastName=Beethovan)
Employee(id=4, age=26, gender=M, firstName=Jon, lastName=Lowman)
Employee(id=3, age=43, gender=M, firstName=Ricky, lastName=Martin)
Employee(id=10, age=45, gender=M, firstName=Naveen, lastName=Jain)
Employee(id=7, age=68, gender=F, firstName=Melissa, lastName=Roy)
Employee(id=8, age=79, gender=M, firstName=Alex, lastName=Gussin)
  • 若是我们希望List根据岁数age的倒序排序,就使用reversed()方式。如:
employees.sort(Comparator.comparing(Employee::getAge).reversed());

四、Comparator链对List<Object>排序

下面这段代码先是按性别的倒序排序,再根据岁数的倒序排序。

employees.sort(
        Comparator.comparing(Employee::getGender)
        .thenComparing(Employee::getAge)
        .reversed()
);
employees.forEach(System.out::println);

//都是正序 ,不加reversed
//都是倒序,最后面加一个reserved
//先是倒序(加reserved),然后正序
//先是正序(加reserved),然后倒序(加reserved)

仔细的同伙可能注重到:我们只用了一个reversed()倒序方式,这个和SQL的表述方式不太一样。这个问题不太好用语言形貌,建议人人去看一下本文对应的视频

排序效果如下:

Employee(id=8, age=79, gender=M, firstName=Alex, lastName=Gussin)
Employee(id=10, age=45, gender=M, firstName=Naveen, lastName=Jain)
Employee(id=3, age=43, gender=M, firstName=Ricky, lastName=Martin)
Employee(id=4, age=26, gender=M, firstName=Jon, lastName=Lowman)
Employee(id=1, age=23, gender=M, firstName=Rick, lastName=Beethovan)
Employee(id=6, age=15, gender=M, firstName=David, lastName=Feezor)
Employee(id=7, age=68, gender=F, firstName=Melissa, lastName=Roy)
Employee(id=5, age=19, gender=F, firstName=Cristine, lastName=Maria)
Employee(id=9, age=15, gender=F, firstName=Neetu, lastName=Singh)
Employee(id=2, age=13, gender=F, firstName=Martina, lastName=Hengis)

迎接关注我的博客,内里有许多精品合集

  • 本文转载注明出处(必须带毗邻,不能只转文字):字母哥博客。

以为对您有辅助的话,帮我点赞、分享!您的支持是我不竭的创作动力! 。另外,笔者最近一段时间输出了如下的精品内容,期待您的关注。

  • 《手摸手教你学Spring Boot2.0》
  • 《Spring Security-JWT-OAuth2一本通》
  • 《实战前后端星散RBAC权限治理系统》
  • 《实战SpringCloud微服务从青铜到王者》
  • 《VUE深入浅出系列》
,

AllbetGmaing手机版下载

欢迎进入AllbetGmaing手机版下载(Allbet Game):www.aLLbetgame.us,欧博官网是欧博集团的官方网站。欧博官网开放Allbet注册、Allbe代理、Allbet电脑客户端、Allbet手机版下载等业务。

Allbet Gaming声明:该文看法仅代表作者自己,与阳光在线无关。转载请注明:欧博亚洲手机版下载:恕我直言你可能真的不会java第7篇:像使用SQL一样排序聚集
发布评论

分享到:

绍兴e网论坛:“为了40块钱她被性侵了”:若干怙恃,亲手把自己变成了孩子最恐惧的人?
2 条回复
  1. allbet欧博真人客户端
    allbet欧博真人客户端
    (2020-07-13 00:08:03) 1#

    AllbetGmaing客户端下载欢迎进入AllbetGmaing客户端下载(www.aLLbetgame.us):www.aLLbetgame.us,欧博官网是欧博集团的官方网站。欧博官网开放Allbet注册、Allbe代理、Allbet电脑客户端、Allbet手机版下载等业务。给你跪了

  2. ALLBET官网娱乐平台开户
    ALLBET官网娱乐平台开户
    (2020-07-31 00:01:17) 2#

    Allbet官网欢迎进入Allbet官网(Allbet Game):www.aLLbetgame.us,欧博官网是欧博集团的官方网站。欧博官网开放Allbet注册、Allbe代理、Allbet电脑客户端、Allbet手机版下载等业务。哈哈,交流起来

发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。