摘要
IntelliJ IDEA老湿机,你竟然没用过Stream Trace?Java 8以来,Stream已成为程序猿的必备利器,写起来感觉so good~但有时操作结果和预期不符,就需要调整和定位。看看这段代码:public static vo…
正文
IntelliJ IDEA 老湿机,还未用过 Stream Trace 作用?
序言
自打 Java 8 逐渐,做为程序猿的大家都离不了 Stream 有关作用的应用,撰写起來那叫一个顺畅(这一 feel~~)。但一直有一些情况下,大家对 stream 的实际操作所需的結果和预估不符合,这就必须大家逐渐调节,精准定位
基本调节
先看来下边这一段编码:
public static void main(String[] args) {
Object[] res = Stream.of(1,2,3,4,5,6,7,8).filter( i -> i%2 == 0).filter( i -> i>3).toArray();
System.out.println(Arrays.toString(res));
}
我们可以在 Stream 实际操作处打上中断点,逐渐查询結果,如同那样:
大家必须各种各样单步调节,并不是很形象化,大家急切的必须个一览主视图,使我们迅速查询大家的 Stream 結果
数据可视化调节
一样先挑选行中断点,以 Debug
方式进到程序流程:
下面会弹出来 Stream Trace
,全部 Stream 实际操作尽展眼下
一样能够点一下左下方的 Flat Mode
按键,将全部主视图扁平化设计
在具体业务流程中,大家一般对结合开展各种各样 Stream 实际操作,大家再说个繁杂一些的事例:
List<Optional<Customer>> customers = Arrays.asList(
Optional.of(new Customer("日拱一兵", 18)),
Optional.of(new Customer("低贱的小开发设计", 22)),
Optional.empty(),
Optional.of(new Customer("OOT", 21)),
Optional.empty(),
Optional.of(new Customer("温柔一刀", 23)),
Optional.empty()
);
long numberOf65PlusCustomers = customers
.stream()
.flatMap(c -> c
.map(Stream::of)
.orElseGet(Stream::empty))
.filter(c -> c.getAge() > 18)
.count();
System.out.println(numberOf65PlusCustomers);
一样依照上边的实际操作获得数据可视化 Stream Trace 主视图,形象化掌握全部 Stream 步骤,查询目标特性等
汇总
这一简易的作用,看一遍便会,坚信能够在日常的调节中对您有非常大协助,下面会详细介绍大量的你未曾注意非常高級调节方法
关注不迷路
扫码下方二维码,关注宇凡盒子公众号,免费获取最新技术内幕!
温馨提示:如果您访问和下载本站资源,表示您已同意只将下载文件用于研究、学习而非其他用途。
评论0