【289期】Java 8 新特性:Comparator.naturalOrder | 自然排序

点击上方“Java精选”,选择“设为星标”

别问别人为什么,多问自己凭什么!

下方有惊喜,留言必回,有问必答!

每一天进步一点点,是成功的开始...

naturalOrder是比较器功能接口的静态方法。

Java 8中引入的Comparator.naturalOrder方法返回一个比较器,该比较器以自然顺序比较可比较对象。

对于自然排序,一个类需要实现Comparable并定义compareTo方法。

一个对象的集合根据compareTo方法以自然排序进行排序。

像Integer、String和Date这样的Java类实现了Comparable接口并覆盖了其compareTo方法,它们以词表顺序(lexicographic-order)进行排序。

从Java源代码中找到naturalOrder方法声明。

static <T extends Comparable<? super T>> Comparator<T> naturalOrder()

为了扭转自然排序,我们可以使用Comparator.reverseOrder方法。

在本页面中,我们将提供一些例子,说明如何使用Comparator.naturalOrderStream.sorted、Collections.sort、List.sortArrays.sort一起对对象的集合进行自然排序。

另外,推荐下 Spring boot 的实战开源项目:
https://gitee.com/yoodb/jing-xuan

与 Stream.sorted 一起使用

Stream.sorted返回一个由这个流的元素组成的流,根据提供的比较器进行排序。

StreamSortedDemo.java

import java.util.Arrays;
import java.util.Comparator;
import java.util.List;
public class StreamSortedDemo {
  public static void main(String[] args) {
 List<Integer> numList = Arrays.asList(12, 10, 15, 8, 11);
 numList.stream().sorted(Comparator.naturalOrder()).forEach(n -> System.out.print(n + " "));
 System.out.println("\n-----------");
 
 List<String> strList = Arrays.asList("Varanasi", "Allahabad", "Kanpur", "Noida");
 strList.stream().sorted(Comparator.naturalOrder()).forEach(s -> System.out.print(s + " "));
 System.out.println("\n-----------"); 
 
 List<Student> stdList = Student.getStudentList();
 stdList.stream().sorted(Comparator.naturalOrder()).forEach(s -> System.out.print(s.getName() + " "));
 System.out.println("\n-----------"); 
 
 //reverse order of natural order using Comparator.reverseOrder()
 stdList = Student.getStudentList();
 stdList.stream().sorted(Comparator.reverseOrder()).forEach(s -> System.out.print(s.getName() + " ")); 
  }
}

Student.java

import java.util.Arrays;
import java.util.List;
public class Student implements Comparable<Student> {
  private String name;
  private int age;
  public Student(String name, int age) {
 this.name = name;
 this.age = age;
  }
  public String getName() {
 return name;
  }
  public int getAge() {
 return age;
  }
  @Override
  public int compareTo(Student s) {
 return name.compareTo(s.getName());
  }
  public static List<Student> getStudentList() {
 Student s1 = new Student("Ram", 18);
 Student s2 = new Student("Shyam", 22);
 Student s3 = new Student("Mohan", 19);
 Student s4 = new Student("Mahesh", 20);
 Student s5 = new Student("Krishna", 21);
 List<Student> list = Arrays.asList(s1, s2, s3, s4, s5);
 return list;
  }
}

输出

8 10 11 12 15 
-----------
Allahabad Kanpur Noida Varanasi 
-----------
Krishna Mahesh Mohan Ram Shyam 
-----------
Shyam Ram Mohan Mahesh Krish

与 Collections.sort 一起使用

Collections.sort根据给定的比较器实例对指定的列表进行排序。

推荐下几个月熬夜整理的近 10000+ 面试资料大全:https://gitee.com/yoodb/ebooks

CollectionsSortDemo.java

import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class CollectionsSortDemo {
  public static void main(String[] args) {
 List<Integer> numList = Arrays.asList(12, 10, 15, 8, 11);
 Collections.sort(numList, Comparator.naturalOrder());
 numList.forEach(n -> System.out.print(n + " "));
 System.out.println("\n-----------");
 
 List<String> strList = Arrays.asList("Varanasi", "Allahabad", "Kanpur", "Noida");
 Collections.sort(strList, Comparator.naturalOrder());
 strList.forEach(s -> System.out.print(s + " "));
 System.out.println("\n-----------"); 
 
 List<Student> stdList = Student.getStudentList();
 Collections.sort(stdList, Comparator.naturalOrder());
 stdList.forEach(s -> System.out.print(s.getName() + " ")); 
  }
}

与 List.sort 一起使用

List.sort根据给定的比较器实例对这个列表进行排序。

ListSortDemo.java

import java.util.Arrays;
import java.util.Comparator;
import java.util.List;
public class ListSortDemo {
  public static void main(String[] args) {
 List<Integer> numList = Arrays.asList(12, 10, 15, 8, 11);
 numList.sort(Comparator.naturalOrder());
 numList.forEach(n -> System.out.print(n + " "));
 System.out.println("\n-----------");
 
 List<String> strList = Arrays.asList("Varanasi", "Allahabad", "Kanpur", "Noida");
 strList.sort(Comparator.naturalOrder());
 strList.forEach(s -> System.out.print(s + " "));
 System.out.println("\n-----------"); 
 
 List<Student> stdList = Student.getStudentList();
 stdList.sort(Comparator.naturalOrder());
 stdList.forEach(s -> System.out.print(s.getName() + " "));
  }
}

与 Arrays.sort 一起使用

Arrays.sort根据指定的比较器引起的顺序对指定的对象阵列进行排序。

ArraysSortDemo.java

import java.util.Arrays;
import java.util.Comparator;
public class ArraysSortDemo {
  public static void main(String[] args) {
 Student s1 = new Student("Ram", 18);
 Student s2 = new Student("Shyam", 22);
 Student s3 = new Student("Mohan", 19);

 Student[] stdArray = { s1, s2, s3 };
 Arrays.sort(stdArray, Comparator.naturalOrder());
 for (Student s : stdArray) {
   System.out.print(s.getName() + " ");
 }
  }
}

作者:猫巳

https://moonce.blog.csdn.net/article/details/120324130

公众号“Java精选”所发表内容注明来源的,版权归原出处所有(无法查证版权的或者未注明出处的均来自网络,系转载,转载的目的在于传递更多信息,版权属于原作者。如有侵权,请联系,笔者会第一时间删除处理!

------ THE END ------

8209796cfbbf147c11f922478a61491a.png精品资料,超赞福利!5c8531f012cb3940dbc3eba1d183edc6.png

>Java精选面试题<
3000+ 道面试题在线刷,最新、最全 Java 面试题!

38961195aea22ff7cb8ec6d8ba0b81c6.png

121cc6ac2036f6dd488a16c1adcb9016.png

期往精选  点击标题可跳转

【281期】面试官问:淘宝七天自动确认收货,可以怎么实现?

【282期】Spring Boot 项目使用 Disruptor 做内部消息队列,没看错!

【283期】面试官问:高并发场景下,如何保证全局唯一分布式 ID 生成?

【284期】高逼格的别样 SQL 写法:行行比较!

【285期】JDK9 为何要将 String 的底层实现由 char[] 改成了 byte[]?

【286期】领域驱动设计(DDD)架构演进和DDD的几种典型架构介绍(图文详解)

【287期】5 款免费又好用的 Docker 管理神器!酷炫到没朋友!

【288期】面试官问:如何解决打开 IDEA 对 CPU 占用率超高的问题?

70e0d3d7d115cf6c3c8f24ff9ef58886.png 技术交流群!fd7fda0b7a6e8b4fb6b83c85053acfcc.png

最近有很多人问,有没有读者交流群!想知道如何加入?方式很简单,兴趣相投的朋友,只需要点击下方卡片,回复“加群”,即可无套路入交流群!

文章有帮助的话,在看,转发吧!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: comparator.naturalOrder()是Java语言中的一个静态方法,用于获取一个自然排序的比较器(Comparator)。 使用这个方法获取的比较器可以对对象进行自然排序,即按照对象的自然顺序进行排序,例如对于数字类型,会按照数字大小进行排序。 举个例子,如果有一个数字数组int[] nums = {3, 1, 4, 1, 5, 9, 2, 6, 5},我们可以使用Arrays.sort(nums, Comparator.naturalOrder())方法进行排序排序后的结果为{1, 1, 2, 3, 4, 5, 5, 6, 9}。 ### 回答2: `comparator.naturalOrder()` 是一个静态方法,它返回一个自然顺序的比较器。在 Java 中,许多类实现了 `Comparable` 接口,该接口定义了对象之间的自然顺序。当你想对这些对象进行排序时,可以使用 `comparator.naturalOrder()` 返回的比较器。 使用 `comparator.naturalOrder()` 方法有两个主要的优点。首先,它提供了一种简单的方式来获取对象的自然顺序比较器,而无需自己实现比较逻辑。其次,使用自然顺序比较器可以让代码更加清晰和易懂,因为它符合人们对对象之间比较的直觉。 例如,如果我们有一个包含整数的列表,我们可以使用 `comparator.naturalOrder()` 方法来对它进行自然顺序排序。示例代码如下: ```java List<Integer> numbers = Arrays.asList(3, 1, 2, 4, 5); numbers.sort(Comparator.naturalOrder()); System.out.println(numbers); // 输出 [1, 2, 3, 4, 5] ``` 在这个例子中,我们使用 `Comparator.naturalOrder()` 方法获取了一个自然顺序的比较器,并将其传递给了 `List` 的 `sort()` 方法。这样,列表中的整数将按照它们的自然顺序进行排序。 需要注意的是,只有实现了 `Comparable` 接口的类才能使用 `comparator.naturalOrder()` 方法,因为它依赖于对象的自然顺序定义。如果类没有实现 `Comparable` 接口,使用 `comparator.naturalOrder()` 方法将会导致编译错误。在这种情况下,可以考虑使用自定义的比较器来对对象进行排序。 ### 回答3: `Comparator.naturalOrder()` 是 Java 中 `Comparator` 接口的一个静态方法,它返回一个使用自然顺序进行比较的 `Comparator` 实例。 在Java中,对一些类如 `String`、`Integer` 等实现了 `Comparable` 接口的类,它们内部已经实现了自然顺序的比较方法。`Comparator.naturalOrder()` 利用这些对象内部已经定义的比较规则,创建了一个使用自然顺序的 `Comparator` 实例。 自然顺序是一种对象的默认排序规则,它根据对象的值进行排序,大多用于基本数据类型和实现了 `Comparable` 接口的类。例如,使用自然顺序比较整数时,比较的是整数的数值大小。 下面是一个使用 `Comparator.naturalOrder()` 的示例: ```java import java.util.Arrays; import java.util.Comparator; public class Main { public static void main(String[] args) { Integer[] numbers = {5, 2, 8, 1, 9}; // 使用自然顺序进行比较排序 Arrays.sort(numbers, Comparator.naturalOrder()); // 输出排序结果 for (Integer number : numbers) { System.out.print(number + " "); } } } ``` 以上代码将会输出:1 2 5 8 9,即按照数值大小进行自然顺序的升序排序。 值得注意的是,`Comparator.naturalOrder()` 只能用于实现了 `Comparable` 接口的类。对于自定义类,如果想要使用自然顺序进行比较,需要在类中实现 `Comparable` 接口的 `compareTo()` 方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值