Java中的排序问题(Java8新特性 stream流、stream多字段排序)

Java中的排序问题(Java8新特性 stream流、stream多字段排序):

学习内容:

一、什么是流
二、stream特性

一、概要
Java 8 API添加了一个新的抽象成为流Stream,它以一种声明的方式处理数据,最后由最终操做获得前面处理的结果。java

    Stream专一于集合对象的操做,将要处理的元素集合看做一种流, 流在管道中传输, 而且能够在管道的节点上进行处理, 好比筛选, 排序,聚合等。程序员

    Stream在处理大批量数据操做中更加高效。算法

    Stream + Lambda 表达式能够极大提升Java程序员的生产力,让程序员写出高效率、干净、简洁的代码。sql

stream的三大特性:一、不存储数据;二、不改变源数据;三、延时执行。数据结构

stream优势:一、简化代码;二、使用并行流能够利用多核特性,提高效率。框架

stream上的全部操做分为两类:中间操做和结束操做,中间操做只是一种标记,只有结束操做才会触发实际计算。

二、什么是流
Stream不是集合元素,它不是数据结构并不保存数据,它是有关算法和计算的,它更像一个高级版本的Iterator。原始版本的Iterator,用户只能显式地一个一个遍历元素并对其执行某些操做;高级版本的Stream,用户只要给出须要对其包含的元素执行什么操做,好比,“过滤掉长度大于 10 的字符串”、“获取每一个字符串的首字母”等,Stream会隐式地在内部进行遍历,作出相应的数据转换。Stream就如同一个迭代器(Iterator),单向,不可往复,数据只能遍历一次,遍历过一次后即用尽了,就比如流水从面前流过,一去不复返。线程

而和迭代器又不一样的是,Stream能够并行化操做,迭代器只能命令式地、串行化操做。顾名思义,当使用串行方式去遍历时,每一个item读完后再读下一个item。而使用并行去遍历时,数据会被分红多个段,其中每一个段在不一样的线程中处理,而后将结果一块儿输出。Stream的并行操做依赖于Java7中引入的Fork/Join框架(JSR166y)来拆分任务和加速处理过程。code

Stream 的另一大特色是,数据源自己能够是无限的。
对象

工做中,常常会须要对集合内的元素进行排序。利用Java8能够很方便的对List内的元素进行排序操做;而在不少状况下sql很差

List 倒序排列
List salesData = new ArrayList<>();

Collections.reverse(salesData);

java8 stream多字段排序

List<类> rankList = new ArrayList<>(); 表明某个集合

//返回 对象集合以类属性一升序排序

rankList.stream().sorted(Comparator.comparing(类::属性一));

//返回 对象集合以类属性一降序排序 注意两种写法

rankList.stream().sorted(Comparator.comparing(类::属性一).reversed()); //先以属性一升序,而后对结果集进行属性一降序

rankList.stream().sorted(Comparator.comparing(类::属性一, Comparator.reverseOrder())); //以属性一降序

//返回 对象集合以类属性一升序 属性二升序

rankList.stream().sorted(Comparator.comparing(类::属性一).thenComparing(类::属性二));

//返回 对象集合以类属性一降序 属性二升序 注意两种写法

rankList.stream().sorted(Comparator.comparing(类::属性一).reversed().thenComparing(类::属性二));//先以属性一升序,升序结果进行属性一降序,再进行属性二升序

rankList.stream().sorted(Comparator.comparing(类::属性一,Comparator.reverseOrder()).thenComparing(类::属性二));//先以属性一降序,再进行属性二升序

//返回 对象集合以类属性一降序 属性二降序 注意两种写法

rankList.stream().sorted(Comparator.comparing(类::属性一).reversed().thenComparing(类::属性二,Comparator.reverseOrder()));//先以属性一升序,升序结果进行属性一降序,再进行属性二降序

rankList.stream().sorted(Comparator.comparing(类::属性一,Comparator.reverseOrder()).thenComparing(类::属性二,Comparator.reverseOrder()));//先以属性一降序,再进行属性二降序

//返回 对象集合以类属性一升序 属性二降序 注意两种写法

rankList.stream().sorted(Comparator.comparing(类::属性一).reversed().thenComparing(类::属性二).reversed());//先以属性一升序,升序结果进行属性一降序,再进行属性二升序,结果进行属性一降序属性二降序

rankList.stream().sorted(Comparator.comparing(类::属性一).thenComparing(类::属性二,Comparator.reverseOrder()));//先以属性一升序,再进行属性二降序

你可能感兴趣的:(Java8,经验分享,程序人生,java)