java8的sorted,Java8排序stream.sorted()

使用Java8排序stream.sorted()

sorted-example

国外对Java8一系列总结的不错, 翻译过来给你们共享

这篇文章将会讲解Java 8 Stream sorted()示例, 咱们可以以天然序或着用Comparator 接口定义的排序规则来排序一个流。Comparator 能用用lambada表达式来初始化, 咱们还可以逆序一个已经排序的流。

接下来咱们将会使用java 8 的流式sorted排序List 、Map 、 Set

一、sorted() 默认使用天然序排序, 其中的元素必须实现Comparable 接口

二、sorted(Comparator super T> comparator) :咱们能够使用lambada 来建立一个Comparator 实例。能够按照升序或着降序来排序元素。

下面代码以天然序排序一个listweb

list.stream().sorted()

1

天然序逆序元素,使用Comparator 提供的reverseOrder() 方法ide

list.stream().sorted(Comparator.reverseOrder())

1

使用Comparator 来排序一个listsvg

list.stream().sorted(Comparator.comparing(Student::getAge))

1

把上面的元素逆序this

list.stream().sorted(Comparator.comparing(Student::getAge).reversed())

1

Stream sorted() with List

咱们排序一组装着Student 类对象的List 集合。 首先咱们使用天然序, 接着咱们使用Comparator 分别进行升序和降序:翻译

SortList.java

package com.concretepage;

import java.util.ArrayList;

import java.util.Comparator;

import java.util.List;

import java.util.stream.Collectors;

public class SortList {

public static void main(String[] args) {

List list = new ArrayList();

list.add(new Student(1, "Mahesh", 12));

list.add(new Student(2, "Suresh", 15));

list.add(new Student(3, "Nilesh", 10));

System.out.println("---Natural Sorting by Name---");

List slist = list.stream().sorted().collect(Collectors.toList());

slist.forEach(e -> System.out.println("Id:"+ e.getId()+", Name: "+e.getName()+", Age:"+e.getAge()));

System.out.println("---Natural Sorting by Name in reverse order---");

slist = list.stream().sorted(Comparator.reverseOrder()).collect(Collectors.toList());

slist.forEach(e -> System.out.println("Id:"+ e.getId()+", Name: "+e.getName()+", Age:"+e.getAge()));

System.out.println("---Sorting using Comparator by Age---");

slist = list.stream().sorted(Comparator.comparing(Student::getAge)).collect(Collectors.toList());

slist.forEach(e -> System.out.println("Id:"+ e.getId()+", Name: "+e.getName()+", Age:"+e.getAge()));

System.out.println("---Sorting using Comparator by Age with reverse order---");

slist = list.stream().sorted(Comparator.comparing(Student::getAge).reversed()).collect(Collectors.toList());

slist.forEach(e -> System.out.println("Id:"+ e.getId()+", Name: "+e.getName()+", Age:"+e.getAge()));

}

}

Student.java *code package com.concretepage;

public class Student implements Comparable {

private int id;

private String name;

private int age;

public Student(int id, String name, int age) {

this.id = id;

this.name = name;

this.age = age;

}

public int getId() {

return id;

}

public String getName() {

return name;

}

public int getAge() {

return age;

}

@Override

public int compareTo(Student ob) {

return name.compareTo(ob.getName());

}

@Override

public boolean equals(final Object obj) {

if (obj == null) {

return false;

}

final Student std = (Student) obj;

if (this == std) {

return true;

} else {

return (this.name.equals(std.name) && (this.age == std.age));

}

}

@Override

public int hashCode() {

int hashno = 7;

hashno = 13 * hashno + (name == null ? 0 : name.hashCode());

return hashno;

}

}

Output *xml

—Natural Sorting by Name—

Id:1, Name: Mahesh, Age:12

Id:3, Name: Nilesh, Age:10

Id:2, Name: Suresh, Age:15

—Natural Sorting by Name in reverse order—

Id:2, Name: Suresh, Age:15

Id:3, Name: Nilesh, Age:10

Id:1, Name: Mahesh, Age:12

—Sorting using Comparator by Age—

Id:3, Name: Nilesh, Age:10

Id:1, Name: Mahesh, Age:12

Id:2, Name: Suresh, Age:15

—Sorting using Comparator by Age with reverse order—

Id:2, Name: Suresh, Age:15

Id:1, Name: Mahesh, Age:12

Id:3, Name: Nilesh, Age:10对象

<think>好的,我现在需要帮助用户解决在Java 8中使用Stream API进行自定义排序的问题。用户希望了解如何实现自定义排序方法,并需要示例代码。首先,我要回顾一下相关的知识,并参考用户提供的引用内容,确保回答准确且符合用户的需求。 首先,Java 8Stream API中的sorted()方法确实可以用于排序。根据引用[5],sorted方法可以对元素进行排序,比如字符串的字典顺序。但用户需要的是自定义排序,这可能涉及到对象属性的比较或更复杂的逻辑。 接下来,引用[1]中的示例展示了如何按年龄升序排序自定义对象,使用的是Comparator.comparingInt(p -> p.age)。这应该是一个基础的自定义排序方法,适用于单一属性。但用户可能需要更多的例子,比如降序排序、多条件排序或使用自定义比较器。 然后,引用[3]提到将Map转换为Stream后,使用sorted()并转换为Map。这可能涉及到对Map的键或值进行排序,但用户的问题是关于自定义排序,所以可能需要展示如何对Map的条目进行排序,例如根据键或值的特定属性。 用户的问题集中在自定义排序方法,因此需要覆盖不同的情况:基本类型、对象属性、多条件、自定义比较器,以及可能的逆序排序。每个情况都应该有示例代码,并解释关键点。 例如,首先展示基本数据类型的排序,比如字符串的升序和降序。然后处理自定义对象,比如按年龄排序,或者按姓名长度排序。接着,多条件排序,比如先按年龄再按姓名。此外,使用自定义Comparator的情况也需要说明,比如当排序逻辑复杂时,可以定义自己的比较方法。 需要注意引用中的内容,如引用[1]中的sorted方法结合Comparator.comparingInt,引用[5]中的sorted()默认排序,引用[3]中的转换步骤。这些都可以整合到回答中,确保引用正确的部分。 此外,用户可能需要了解如何处理逆序排序,这可以通过Comparator的reversed()方法实现。例如,Comparator.comparingInt(Person::getAge).reversed()。 还要注意可能的异常情况,如引用[3]提到的Collectors.toMap可能抛出IllegalStateException,但这个问题在排序过程中可能不直接相关,但如果在收集时使用toMap需要注意键的唯一性。 最后,生成相关问题,帮助用户深入理解。比如如何实现多条件排序、如何处理降序、性能优化等。 现在需要组织这些思路,结构清晰,分点说明,并附上代码示例,确保符合用户的要求:使用中文,正确LaTeX格式,引用标识,以及相关问题。</think>### Java 8 Stream API 自定义排序方法详解 #### 一、基础排序实现 1. **基本数据类型排序** - 对字符串列表进行**字典升序**排序: ```java List<String> list = Arrays.asList("d", "a", "c", "b"); List<String> sortedList = list.stream() .sorted() //默认升序 .collect(Collectors.toList()); //输出: [a, b, c, d][^2][^5] ``` - 实现**降序排序**: ```java List<String> reversedList = list.stream() .sorted(Comparator.reverseOrder()) .collect(Collectors.toList()); //输出: [d, c, b, a] ``` 2. **自定义对象排序** 假设有`Person`类,包含`name`和`age`属性: ```java class Person { String name; int age; //构造函数、getter、toString } ``` - **按年龄升序**排序: ```java List<Person> sortedByAge = persons.stream() .sorted(Comparator.comparingInt(Person::getAge)) .collect(Collectors.toList()); //示例输出: [Bob (25), Alice (30), Charlie (35)][^1] ``` - **按年龄降序**排序: ```java List<Person> reversedByAge = persons.stream() .sorted(Comparator.comparingInt(Person::getAge).reversed()) .collect(Collectors.toList()); ``` #### 二、多条件排序 通过链式调用实现**复合排序规则**: ```java //先按年龄升序,年龄相同则按姓名字典序排序 List<Person> multiSorted = persons.stream() .sorted(Comparator.comparingInt(Person::getAge) .thenComparing(Person::getName)) .collect(Collectors.toList()); ``` #### 三、自定义比较器 当需要**复杂逻辑**时,可通过`Comparator`自定义规则: ```java //按姓名长度排序,长度相同则按字典逆序 List<Person> customSorted = persons.stream() .sorted((p1, p2) -> { int lengthCompare = Integer.compare(p1.getName().length(), p2.getName().length()); return lengthCompare != 0 ? lengthCompare : p2.getName().compareTo(p1.getName()); }) .collect(Collectors.toList()); ``` #### 四、Map排序示例 对`Map<String, Integer>`按值降序排序: ```java Map<String, Integer> map = new HashMap<>(); map.put("Apple", 50); map.put("Banana", 20); map.put("Cherry", 70); Map<String, Integer> sortedMap = map.entrySet().stream() .sorted(Map.Entry.<String, Integer>comparingByValue().reversed()) .collect(Collectors.toMap( Map.Entry::getKey, Map.Entry::getValue, (oldVal, newVal) -> oldVal, //解决键冲突 LinkedHashMap::new //保持顺序 )); //输出: {Cherry=70, Apple=50, Banana=20}[^3] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值