初探Lambda表达式/Java多核编程【1】从集合到流
从集合到流
接上一小节初探Lambda表达式/Java多核编程【0】从外部迭代到内部迭代,本小节将着手使用“流”这一概念进行“迭代”操作。
首先何为“迭代”。其意为对某一对象进行某种操作,并把结果作为下一次操作的输入,如此往复进行,直至得到或逼近预期结果。
现在我们用代码来具体表示对某一集合进行迭代操作,我们希望定义一个Contact类来表示联系人,并将ContactList中所有String类型的联系人姓名全部包装进Contact类中:
List<Contact> contacts = new ArrayList<>();
contactList.forEach(new Consumer<String>() {
@Override
public void accept(String s) {
Contact contact = new Contact();
contact.setName(s);
contacts.add(contact);
}
});
接下来我们希望筛选出所有还能打通的联系人,将其放入一个有效联系人集合:
List<Contact> validContacts = new ArrayList<>();
contacts.forEach(new Consumer<Contact>() {
@Override
public void accept(Contact c) {
if (c.call())
validContacts.add(c);
}
});
System.out.println(validContacts.size());
可以看出,第一次操作我们将String类型的数据转换为Contact,第二次则对每一个Contact调用call()方法,筛选出返回结果为true的联系人并将其收集进另一个集合,最后我们统计出还能打通的联系人数目。
在此过程中,操作行为完全封闭在各个集合内部,无需引入任何外部变量。
从处理开始、进行到结束,对象在操作间如同一个有序序列在移动,这就是流的特征,即“移动中的数据”。
真正的流与集合大相径庭,其只表示一种“可选的有序值序列”,而“无需为这些值提供任何存储”,这就是为何Stream在Java8-API中被定义为接口而非一种类。
public interface Stream<T> extends BaseStream<T, Stream<T>> {}
Stream<T>为对象的流,而DoubleStream、LongStream以及IntStream则为double、long以及int这三种基本类型的流。
现在我们再将第一次从String到Contact的映射用流的方式来重写:
Stream<Contact> contactStream = contactList.stream().map(s -> new Contact().setName(s));
stream()从源中取得管道,表示流的开始。
map()接收管道中的流并对齐进行某种变换,在本例中,我们将管道中的String映射成为Contact类,自此,String管道成为Contact管道。
我们可以将上一段代码拆分为:
Stream<String> stringStream = contactList.stream();
Stream<Contact> contactStream1 = stringStream.map(s -> new Contact().setName(s));
在基本搞清了流操作之后,我们现在一气呵成,直接使用流得到最终结果:
long validContactCounter =
contactList.stream()
.map(s -> new Contact().setName(s))
.filter(c -> c.call())
.count();
可以看出,我们对流能够进行丰富的操作,过滤、计数、查找等等,在此不表。
小结
使用流的方式处理数据能够精简代码,同时突出了所要进行的操作,当然乍看以来有些难懂。
既然牺牲了些许可读性,但是作为交换条件,我们在这种顺序执行的流操作中,获得了两倍于相应的循环版本的性能。
同样,并行执行流操作对于大型数据集将产生非凡的效果。
本小结相关代码:
(Contact.java)
```java
import java.util.Random;
public class Contact {
private String name;
private long number;
private Random random;
public Contact() {
random = new Random();
}
public String getName() {
return name;
}
public Contact setName(String name) {
this.name = name;
return this;
}
public long getNumber() {
return number;
}
public Contact setNumber(long number) {
this.number = number;
return this;
}
public boolean call() {
return random.nextBoolean();
}
}
(运行用)java
List
//--- Stream is coming ---//
Stream
//--- Break this code ---//
Stream
//--- All in one ---//
long validContactCounter =
contactList.stream()
.map(s -> new Contact().setName(s))
.filter(c -> c.call())
.count();
System.out.println(validContactCounter);
以及运行结果:java
3
3
```
初探Lambda表达式/Java多核编程【1】从集合到流的更多相关文章
- 初探Lambda表达式/Java多核编程【2】并行与组合行为
今天又翻了一下书的目录,第一章在这之后就结束了.也就是说,这本书所涉及到的新的知识已经全部点到了. 书的其余部分就是对这几个概念做一些基础知识的补充以及更深层次的实践. 最后两个小节的内容较少,所以合 ...
- 初探Lambda表达式/Java多核编程【3】Lambda语法与作用域
接上一篇:初探Lambda表达式/Java多核编程[2]并行与组合行为 本节是第二章开篇,前一章已经浅显地将所有新概念点到,书中剩下的部分将对这些概念做一个基础知识的补充与深入探讨实践. 本章将介绍L ...
- 初探Lambda表达式/Java多核编程【4】Lambda变量捕获
这周开学,上了两天感觉课好多,学校现在还停水,宿舍网络也还没通,简直爆炸,感觉能静下心看书的时间越来越少了...寒假还有些看过书之后的存货,现在写一点发出来.加上假期两个月左右都过去了书才看了1/7都 ...
- 初探Lambda表达式/Java多核编程【0】从外部迭代到内部迭代
开篇 放假前从学校图书馆中借来一本书,Oracle官方的<精通Lambda表达式:Java多核编程>. 假期已过大半才想起来还没翻上几页,在此先推荐给大家. 此书内容及其简洁干练,如果你对 ...
- Lambda&Java多核编程-5-函数式接口与function包
从前面的总结中我们知道Lambda的使用场景是实现一个函数式接口,那么本篇就将阐述一下何为函数式接口以及Java的function包中提供的几种函数原型. 函数式接口 早期也叫作SAM(Single ...
- Lambda&Java多核编程-6-方法与构造器引用
在Lambda&Java多核编程-2-并行与组合行为一文中,我们对Stream<Contact>里的每一位联系人调用call()方法,并根据能否打通的返回结果过滤掉已经失效的项. ...
- Lambda表达式和函数式编程
Lambda表达式和函数式编程 https://www.cnblogs.com/bigbigbigo/p/8422579.html https://www.runoob.com/java/java8- ...
- Lambda&Java多核编程-7-类型检查
本篇主要介绍Lambda的类型检查机制以及周边的一些知识. 类型检查 在前面的实践中,我们发现表达式的类型能够被上下文所推断.即使同一个表达式,在不同的语境下也能够被推断成不同类型. 这几天在码一个安 ...
- Lambda 表达式(C# 编程指南) 微软microsoft官方说明
Visual Studio 2013 其他版本 Lambda 表达式是一种可用于创建委托或表达式目录树类型的匿名函数. 通过使用 lambda 表达式,可以写入可作为参数传递或作为函数调用值返回的本地 ...
随机推荐
- PHP获取当期前运行文件的路径,名字,服务器路径
<?phpecho "显示脚本文件的相对路径和文件名:\"".$_SERVER["PHP_SELF"]."\"<br& ...
- 如何获取app的素材,做出一个高仿的app
第一步:在iTunes中搜索你想要的app,然后点击下载: 下载完成之后右键点击:在Finder中显示 在finder中右键用"归档工具打开" 会显示如下内容: "显示包 ...
- CentOS 7 安装配置 NFS
CentOS 7 安装配置 NFS 环境 nps 192.168.1.97 client 192.168.1.98 一.yum 安装 yum -y install nfs-utils rpcbind ...
- Spark1.3.0安装
之前在用Hadoop写ML算法的时候就隐约感觉Hadoop实在是不适合ML这些比较复杂的算法.记得当时写完kmeans后,发现每个job完成后都需要将结果放在HDFS中,然后下次迭代的时候再从文件中读 ...
- LPC1788的IIC使用
#ifndef __IIC0_H_ #define __IIC0_H_ #include "common.h" #include "delay.h" //IIC ...
- ue4中窗口打开web地址
首先打开项目,设置,widgets,启用webbroswer 新建一个蓝图, 在控件栏里就可以找到添加webbroswer 设置initial url就可以打开网页了, 项目中还用到获取界面参数,与界 ...
- iOS所有常用证书,appID,Provisioning Profiles配置说明及制作图文教程
概述: 苹果的证书繁锁复杂,制作管理相当麻烦,今天决定重置一个游戏项目中的所有证书,做了这么多次还是感觉很纠结,索性直接记录下来,日后你我他查阅都方便: 首先得描述一下各个证书的定位,作用,这样在制作 ...
- Cookie和Session的区别、优缺点
1.cookie数据存放在客户的浏览器上,session数据放在服务器上. 2.cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗 考虑到安全应当使用session 3 ...
- html&&css 基础知识笔记
diV有 Class.Style.title.ID 等属性. 1.margin 空出边缘 margin:上 下 左 右(按顺时针顺序,缺少某一方向则对称) 2.border 边框(三要素:像素 形状 ...
- windowsxp系统下SVN添加新用户
以我部署的文件为例: 我在f盘下新建一个zzz文件夹将其部署为svn共享工程后,新来员工需要添加svn账号以获取工程. 总共三步begin: 1.进入工程文件夹ZZZ在里面有一个conf文件夹如图: ...