java Comparator中的返回值和排序有啥关系啊,求解释!!!!!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java Comparator中的返回值和排序有啥关系啊,求解释!!!!!相关的知识,希望对你有一定的参考价值。

负数代表左值小于右值,排在上面
正数代表左值大于右值,排在下面
0代表左值等于右值,排在上面
可以这样理解:排序就是比较谁大谁小,将小的放在前面,大的放在后面。例如当返回负数的时候,表明第一个数应该排在第二个数的上面。
参考技术A 该接口用于对象与对象间的比较,返回值意味着这两对象之间的大小关系。
-1代表前者小,0代表两者相等,1代表前者大。
参考技术B 一个简单的示例。随机生成长度为20的数值在100以内的数组。输出结果在最下边。
Random random = new Random();
List<Integer> list = new ArrayList<>();
for (int i = 0; i < 20; i++) 
list.add(random.nextInt(100));


Collections.sort(list, new Comparator<Integer>() 
@Override
public int compare(Integer o1, Integer o2) 
if (o1 > o2) 
return 1;

if (o1 < o2) 
return -1;

return 0;

);

System.out.println(Arrays.toString(list.toArray()));
Collections.sort(list, new Comparator<Integer>() 
@Override
public int compare(Integer o1, Integer o2) 
if (o1 < o2) 
return 1;

if (o1 > o2) 
return -1;


return 0;

);

System.out.println(Arrays.toString(list.toArray()));
// 输出结果:
// [6, 9, 24, 28, 34, 45, 46, 49, 54, 56, 58, 58, 59, 60, 71, 74, 85, 91, 91, 96]
// [96, 91, 91, 85, 74, 71, 60, 59, 58, 58, 56, 54, 49, 46, 45, 34, 28, 24, 9, 6]

Java 8 新特性:Comparator.naturalOrder | 自然排序

点击关注公众号,实用技术文章及时了解

来源:moonce.blog.csdn.net/article/

details/120324130

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一起对对象的集合进行自然排序。

与 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根据给定的比较器实例对指定的列表进行排序。

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() + " ");
 
  

推荐

主流Java进阶技术(学习资料分享)

Java面试题宝典

加入Spring技术开发社区

PS:因为公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。点“在看”支持我们吧!

以上是关于java Comparator中的返回值和排序有啥关系啊,求解释!!!!!的主要内容,如果未能解决你的问题,请参考以下文章

错误记录Java 中 ArrayList 排序 ( 使用 Comparator 接口时注意 compare 返回值是 -1 和 +1 )

请教:JAVA中,comparator接口如何对double型数据进行排序。

Collections.sort排序时,重写Comparator自定义排序报java.lang.AbstractMethodError异常,

Java中,构造函数没有返回值。请问没有返回值和返回值类型为void,有啥区别?

Java中的comparable接口和Comparator接口的区别

Comparable与Comparator,java中的排序与比较