List:先来个简单:
List<Integer> list = Arrays.asList(50,800,400,600,60);
System.out.println(java.util.Collections.max(list));//获取最大数
System.out.println(java.util.Collections.min(list));//获取最小数
//可用于数组,数组的话将list.stream()换成Arrays.stream(数组对象名)就行了
System.out.println(list.stream().max(Integer::compareTo).get());//最大数
System.out.println(list.stream().min(Integer::compareTo).get());//最小数
System.out.println(list.stream().collect(Collectors.toList()));//排序,从小到大
System.out.println(list.stream().sorted(Comparator.reverseOrder()).collect(Collectors.toList()));//从大到小;
上面我们讲解了list简单的排序,List 这个T为基本类型的封装类,如果这个T,是一个实体类对象时,我们应该已什么样的方法,使用最少的代码对他们进行排序呢
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;
class User {
private int id;
private String name;
public User(int id, String name) {
this.id = id;
= name;
}
public int getId() {return id;}
public String getName() {return name;}
@Override
public String toString() { return "User{id=" + id + ", name='" + name + '}';}
}
public class Model {
public static void main(String[] args) {
List<User> list = new ArrayList<>();
list.add(new User(4, "李四"));
list.add(new User(3, "张三"));
list.add(new User(5, "王五"));
list.add(new User(1, "大娃"));
list.forEach(item -> System.out.println(item.toString()));
System.out.println("===========根据实体类User中的id属性进行从小到大排序======================");
list=list.stream().sorted(Comparator.comparing(User::getId)).collect(Collectors.toList());
list.forEach(item -> System.out.println(item.toString()));
System.out.println("===========根据实体类User中的id属性进行从大到小排序======================");
list=list.stream().sorted(Comparator.comparing(User::getId).reversed()).collect(Collectors.toList());
list.forEach(item -> System.out.println(item.toString()));
}
}