随着学习的深入,jdk8的改变和强大远超出我的理解。
由lamdba表达式引起的再一次思考,先贴出来这一块的代码
List<CartDTO> cartDTOList = orderDTO.getOrderDetailList().stream().map((e) ->
new CartDTO(e.getProductId(),e.getProductQuantity())
).collect(Collectors.toList());作用顾名思义,遍历orderDTO的list属性,添加cartDTO对象,同时将这个list返回给List<CartDTO> cartDTOList。
正常的逻辑是要遍历orderDTO.getOrderDetailList(),然后cartDTOLIST一个一个的add,这样也可以,但是麻烦,效率没有这种高。
java8支持将collection流化,也就是.stream()方法。在java8中加入了stream类,在这个类中新定义了很多方法,
并且大量使用了default,static等方法。这些不算是抽象方法。所以类上加上@FunctionalInterface注解后依然可以使用
lambda表达式。
逻辑: stream(),序列化流--> 中间操作map(将new的对象赋值给e,e为序列化流的那个collection中的每个元素),
最后一步为将流转化为list。
有很多api,写出来要太长时间。下面按顺序贴一下我感觉比较有用的关于这部分的帖子。
https://blog.youkuaiyun.com/u014646662/article/details/52261511
http://www.importnew.com/16436.html
https://www.cnblogs.com/qdwyg2013/p/5631057.html
附:唱腔另类这首歌真好听啊~嘿嘿
本文通过一个具体的代码示例介绍了如何利用Java 8的Stream API进行高效的数据处理。通过对List的流式操作,实现了对订单详情的转换并收集为新的CartDTO对象列表。这种方式不仅简化了代码,还提高了执行效率。
1669

被折叠的 条评论
为什么被折叠?



