廖雪峰Java16函数式编程-2Stream-7其他操作
1. 排序
Stream<T> sorted(); //按元素默认大小排序(必须实现Comparable接口)
Stream<T> sorted(Comparator<? super T> cp); //按指定Comparator比较的结果排序
public static void main(String[] args){
Stream<String> s = Stream.of("hello","JAVA","python","RUBY","PHP");
s.sorted().forEach(str-> System.out.print(str+"\t"));
System.out.println();
Stream<Integer> s1 = Stream.of(1,9,5,3,7);
s1.sorted(Comparator.reverseOrder()).forEach(str-> System.out.print(str+"\t"));
}

## 2.去除重复元素
Stream distinct(); //返回去除重复元素的Stream
```#java
Stream s = Stream.of("hello","JAVA","hello","RUBY","JAVA");
s.distinct().forEach(str-> System.out.print(str+"\t"));
```

3. 截取
Stream<T> limit(long); //截取Stream前long个元素
Stream<T> skip(long); //跳过Stream前long个元素
Stream<String> s = Stream.of("hello","JAVA","hello","RUBY","JAVA");
s.limit(3).forEach(str-> System.out.print(str+"\t"));
System.out.println();
Stream<Integer> s1 = Stream.of(1,9,5,3,7);
s1.skip(3).forEach(str-> System.out.print(str+"\t"));

4. concat合并
Stream<String> s1 = Stream.of("php","JAVA","python");
Stream<String> s2 = Stream.of("android", "ios");
Stream<String> s = Stream.concat(s1,s2);
s.forEach(str-> System.out.print(str+"\t"));

## 5. flatMap把列表的元素取出,构成一个新的Stream
把元素映射为Stream,然后合并成一个新的Stream

List<String> s1 = new ArrayList<>();
s1.add( "php");
s1.add("JAVA");
s1.add("python");
List<String> s2 = Arrays.asList("android", "ios");
Stream<List> l = Stream.of(s1,s2);
Stream<String> s = l.flatMap(list -> list.stream());
s.forEach(str-> System.out.print(str+"\t"));

6. parallel把一个Stream转换为可以并行处理的Stream
Stream的元素是串行处理的,也就是只能用单线程来处理,如果要提高效率,比如进行并行排序,只需使用parallel()就可以把一个Stream变成一个并行处理的Stream,通过这个方法调用,后续的操作会尽量的并行处理。
Stream<String> s = Stream.of("php","JAVA","python","android", "ios");
String[] result = s.parallel() //变成一个可以并行处理的Stream
.sorted(). //可以进行并行排序
toArray(String[]::new);
System.out.println(Arrays.toString(result));

## 7. Stream的聚合方法
Optional reduce(BinaryOperater bo)
long count()
T max(Comparator cp)//查找最大元素
T min(Comparator cp) //查找最下元素
针对IntStream, longStream, DoubleStream:
```#java
sum() //求和
average() //求平均值
```
```#java
Integer[] nums = {1,2,3,4,5,6};
long max = Stream.of(nums).max((i1,i2)->i1.compareTo(i2)).get();
long min = Stream.of(nums).min((i1,i2)->i1.compareTo(i2)).get();
System.out.println("最大值:"+max+"\t最小值:"+min);
IntStream ins1 = IntStream.builder().add(1).add(2).add(3).add(4).add(5).add(6).build();
IntStream ins2 = IntStream.builder().add(1).add(2).add(3).add(4).add(5).add(6).build();
Double avg = ins1.average().getAsDouble();
long sum = ins2.sum();
System.out.println("求和:"+sum+"\t平均值:"+avg);
```

## 8. 测试Stream的元素是否满足
boolean allMatch(Predicate) //所有元素均满足测试条件
boolean anyMatch(Predicate) //至少一个元素满足测试条件
```#java
Integer[] nums = {1,2,3,4,5,6};
boolean max = Stream.of(nums).allMatch(x->x>0);
boolean min = Stream.of(nums).anyMatch(x->x>5);
System.out.println("元素全部>0:"+max+"\t存在元素>5:"+min);
```

## 9. forEach循环处理Stream的元素
void forEach(Consumer action)
## 10. 把Stream转换为其他类型
Object[] toArray() //转换为Object数组
A[] toArray(IntFunction) //转换为A[]数组
R collect(Collector Collector) //转换为List/Set等集合类型
```#java
Stream s1 = Stream.of("php","JAVA","python","android", "ios");
String[] arr = s1.toArray(String[]::new);
Stream s2 = Stream.of("php","JAVA","python","android", "ios");
List list = s2.collect(Collectors.toList());
System.out.println(Arrays.toString(arr));
System.out.println(list.toString());
```

## 11. 总结
java.util.stream.Stream题哦那个了许多实用的功能
* 转换操作:map,filter,sorted,distinct
* 合并操作:concat,flatMap
* 并行处理:parallel
* 聚合操作:reduce,count,max,min,sum,average
* 其他操作:allMatch,anyMatch,forEach
参考
[https://blog.csdn.net/qq_28410283/article/details/80783505](https://blog.csdn.net/qq_28410283/article/details/80783505)
[https://www.cnblogs.com/a-du/p/8289537.html](https://www.cnblogs.com/a-du/p/8289537.html)
廖雪峰Java16函数式编程-2Stream-7其他操作的更多相关文章
- 廖雪峰Java16函数式编程-1Lambda表达式-1Lambda基础
1. 函数式编程 Java有2类方法: 实例方法:通过实例调用 静态方法:通过类名调用 Java的方法相当于过程式语言的函数 函数式编程(Functional Programing): 把函数作为基本 ...
- 廖雪峰Java16函数式编程-2Stream-6reduce
1. 聚合方法 Stream.reduce()是一个Stream的聚合方法:把一个Stream的所有元素聚合成一个结果 例如: Stream.of(1, 2, 3, 4, 5).count(); // ...
- 廖雪峰Java16函数式编程-2Stream-5filter
1.filter简介 Stream.filter()是一个转换方法,把一个Stream转换为另一个Stream. 所谓filter操作,就是对一个Stream的所有元素进行测试,不满足条件的元素就被过 ...
- 廖雪峰Java16函数式编程-2Stream-4map
1. map()简介 Stream.map()是一个Stream的转换方法,把一个stream转换为另一个Stream,这2个Stream是按照映射函数一一对应的. 所谓map操作,就是把一种操作运算 ...
- 廖雪峰Java16函数式编程-2Stream-2创建Stream
1. 方法1:把一个现有的序列变为Stream,它的元素是固定的 //1.直接通过Stream.of()静态方法传入可变参数进行创建 Stream<Integer> s = Stream. ...
- 廖雪峰Java16函数式编程-2Stream-1Stream简介
1. Stream Java8引入全新的Stream API 位于java.util.stream包 1.1 Stream API不同于java.io的InputStream/OutputStream ...
- 廖雪峰Java16函数式编程-1Lambda表达式-3方法引用
Java8引入了Lambda表达式,可以不必编写FunctionalInterface的实现类,直接写Lambda表达式.除了Lambda表达式,我们还可以直接传入方法引用 方法引用是指:如果某个方法 ...
- [python学习篇][廖雪峰][2]函数式编程
函数名也是变量: >>> f = abs >>> f(-10) 10 然变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就 ...
- 廖雪峰Java6 IO编程-2input和output-5操作zip
1.ZipInputStream是一种FilterInputStream 可以直接读取zip的内容 InputStream->FilterInputStream->InflateInput ...
随机推荐
- python颜色
# python终端显示彩色字符类,可以调用不同的方法# 选择不同的颜色.使用方法看示例代码就很容易明白.# --------------------------------------------- ...
- RMQ 模板题 poj 3264
题目:点这里 题意:给一个长度n的数列,然后又Q个询问,问L 到R 中最大值与最小值的差. 分析:RMQ 的模板题. 代码: #include<stdio.h> #include& ...
- 编写一个简单的内核驱动模块时报错 “/lib/modules/3.13.0-32-generic/bulid: 没有那个文件或目录。 停止。”
编写一个简单的内核驱动模块 static int hello_init() { printk(“hello,I am in kernel now\n”); ; } void addfunc(int a ...
- 5.1中容器(Container)和门面(Facade)的实现
tp5.1中引入了容器(Container)和门面(Facade)这两个新的类 官方文档已经给出了定义: 容器(Container)实现类的统一管理,确保对象实例的唯一性. 门面(Facade)为容器 ...
- Berry 指令设计
Berry 脚本源代码需要被编译为字节码指令流才能被 Berry 虚拟机执行.本文将详细地讲解 Berry 字节码指令(下面简称指令)的设计和实现.为了达到这个目的,本文由 3 部分构成:第 1 小节 ...
- 1.Struts2快速入门
Struts2是一个基于MVC设计模式的Web层框架 Web层框架的特点:前端控制器模式 快速入门 1.下载Struts2的框架包 https://struts.apache.org/ 2.导入jar ...
- 2 java程序入门
1. 第一个java class { public static void main(String[] args) { System.out.println("Hello World!& ...
- Dao层结合Service层处理异常
1. 接口存在异常不利于解耦. 2. 将编译时异常转化为运行时异常或其子类,通知上层,上层可以根据自身能力选择处理或向上抛出. 举例: 将UserDao中的SQLException转化为DaoExce ...
- lua的运算符
1.赋值运算符 --赋值 str="helllo".."world" print(str) a,b=10,20 print(a,b) c,d,e=1,2 pri ...
- IOI 2005 River (洛谷 3354)
题目描述 几乎整个Byteland王国都被森林和河流所覆盖.小点的河汇聚到一起,形成了稍大点的河.就这样,所有的河水都汇聚并流进了一条大河,最后这条大河流进了大海.这条大河的入海口处有一个村庄--名叫 ...