基于Java8StreamAPI如何实现数据抽取收集-创新互联
这篇文章主要介绍了基于Java8 Stream API如何实现数据抽取收集,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
网站建设哪家好,找创新互联!专注于网页设计、网站建设、微信开发、微信小程序定制开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了平湖免费建站欢迎大家使用!目标&背景
我们以“处理订单数据”为例,假设我们的应用是一个分布式应用,有"订单应用","物流应用","商品应用”等都是独立的服务。本次我们的目的需要展示订单列表完整数据:
1.查询订单列表。
2.批量查询物流信息。
3.将物流信息填充到订单主信息中。
假设我们定义了一个订单类,具有几个关键的属性:订单号,状态,订单价,快递信息。如下所示:
class Order{ String orderSeq; String status; double totalPrice; String expressInfo; // 省略get,set及hashCode等方法 }
我们定义了一个快递信息类,几个关键的属性:订单号,物流公司,物流单号,物流状态。如下所示:
class ExpressInfo{ String orderSeq; String expressName; String expressNo; String createTime; String statusInfo; // 省略get,set及hashCode等方法 }
Java7 实现
获取订单列表 & 抽取订单号
ListorderList = getOrderList(); // 抽取 订单号 List orderSeqList = new ArrayList<>(); for (Order order : orderList) { orderSeqList.add(order.getOrderSeq()); }
这里我们获取了订单列表orderList,此时expressInfo里边是没有数据的。这里抽取单号依然是Java传统的写法。
批量查询快递信息 & 组装 订单-快递信息 map
由于我们是通过调用远程服务来获取快递信息,为了减少网络通信次数,我们采取批量查询的方式。这也是为什么,上一步中我们要抽取订单号
下面我们来获取快递信息
// 调用远程服务, ListexpressInfos = RpcGetExpressInfoBatch(orderSeqList); // 组装 订单-快递 关系map Map orderExpressMap = new HashMap<>(); for(ExpressInfo e: expressInfos){ orderExpressMap.put(e.getOrderSeq(),e.getStatusInfo()); }
这里组装map,也依然是Java7常用的写法。
组合数据,将快递信息填充进订单#
for(Order order:orderList){ String expressInfo = orderExpressMap.get(order.getOrderSeq()); order.setExpressInfo(expressInfo); }
至此,我们使用Java7 的写法,完成了开篇设定的目标。下面我们看Java8的写法
Java8 实现
获取订单列表 & 抽取订单号#
// 获取列表 ListorderList = getOrderList(); // 抽取单号 List orderSeqs = orderList.stream() .map(Order::getOrderSeq) .collect(Collectors.toList());
这里我们使用了stream.map,在map()中,我们的写法是Order::getOrderSeq表示调用Order对象的getOrderSeq()方法来抽取订单号。
这里的::叫“方法应用”,是Java8中的新写法。
在map()后面紧跟的是collect收集器,他将抽取的数据toList(),于是我们得到了最终的List。
批量查询快递信息 & 组装 订单-快递信息 map
下面我们仍然是通过远程调用来获取快递信息,然后使用Java8的语法建立一个 订单-快递 关联信息的map。
ListexpressInfos = RpcGetExpressInfoBatch(orderSeqList); Map orderExpressMap =expressInfos.stream() .collect(Collectors.toMap(ExpressInfo::getOrderSeq,ExpressInfo::getStatusInfo));
这里代码比Java7的要少吧,且一目了然,这里用strean().collect来收集数据,收集成什么形式呢?看名知意,Collectors.toMap收集成Map,收集什么数据呢?toMap()中,写了ExpressInfo::getOrderSeq及ExpressInfo::getStatusInfo,即:抽取orderSeq作为key,statusInfo作为value。
至此,订单数据,订单-物流关系数据map都得到了,下面我们来组合数据。
组合数据,将快递信息填充进订单#
经过上面啰嗦的两步,我们得到了符合我们要求的数据,现在我们需要根据颜值高低进行排名,代码如下:
orderList.stream().forEach(o -> o.setExpressInfo(orderExpressMap.get(o.getOrderSeq())));
Java有哪些集合类
Java中的集合主要分为四类:1、List列表:有序的,可重复的;2、Queue队列:有序,可重复的;3、Set集合:不可重复;4、Map映射:无序,键唯一,值不唯一。
感谢你能够认真阅读完这篇文章,希望小编分享的“基于Java8 Stream API如何实现数据抽取收集”这篇文章对大家有帮助,同时也希望大家多多支持创新互联建站,关注创新互联网站建设公司行业资讯频道,更多相关知识等着你来学习!
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
名称栏目:基于Java8StreamAPI如何实现数据抽取收集-创新互联
转载注明:http://scyanting.com/article/dehjce.html