Java效率提升之 你现在还不会Stream() 函数式遍历集合?

JDK1.8的作者是Scala的作者 所以必然 --> FP(函数式编程)

stream()函数是主要用于集合而言的,对于数组就没效果

生成流函数

把集合装成流,可以多次使用这个集合,但是不转换流的话,只能用一次,这就是转换成流的好处

stream() − 为集合创建串行流。

parallelStream() − 为集合创建并行流。

List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());

forEach

用jdk8来遍历集合效果很快,代码如下:

List<String> list =Arrays.asList("a","ad","dr");
list.stream().forEach(System.out::println);
//或者如下也可以
list.stream().forEach(a -> System.out.println(a));
//或者不创建流也可以直接使用函数
list.forEach(System.out::println);
//或者
list.forEach(a -> System.out.println(a));

limit

主要用来限制显示的量:eg:

//该random函数若是不传递参数,那么就采用当前时间的毫秒数当做种子数,若是传递了参数,就用传递的数字作为种子数了,但是这样的话,生成的随机数就是伪随机数,虽然随机,但是点几次,都基本一样,因为传入的种子数限制了函数的选择性
Random random = new Random();
//受到limit限制,只会随机显示10个数字,因为没有传递参数,那么每次点击都会不一样,否则,若传递了种子数,点击几次都一样
random.ints().limit(10).forEach(System.out::println);

//像下面的都一样
Random random = new Random(10);//传递了种子数
random.ints().limit(10).forEach(System.out::println);

map函数

主要用来对传入的参数进行逻辑处理,例如:

//用数组来转换集合
List<Integer> list = Arrays.asList(9,3,3);
//distinct()函数,是去重复函数
list = list.stream().distinct().map(i -> i*i).collect(Collectors.toList());
//打印输出list
list.forEach(System.out::println);

Filter函数

用来过滤所需要的数据

List<String> list = Arrays.asList("1","sd");
list = list.stream().filter(i -> !i.isEmpty()).collect(Collectors.toList());

Collectors函数

可以集合成所需要的集合类型

List<String> list =Arrays.toList("asd","dsg");
//把list集合转换成带逗号“,”的字符串
String str=list.stream().filter(a -> !a.isEmpty()).collect(Collectors.joining(","));
//把得到的字符串转换为了数组了
String[] split = str.split(",");

统计函数

用来统计数组集合的最大最小平均总和的各个值

List<Integer> list = Arrays.asList(12,34,23,12,3,34);
IntSummaryStatistics stats= list.stream().mapToInt(x -> x).summaryStatistics();
//最大值
stats.getMax();
//最小值
stats.getMin();
//平均值
stats.getAverage();
//总数
stats.getCount();
//总和
stats.getSum();

你可能感兴趣的:(build-in,class,分析,字符串,java,stream)