• 汝林外史
    置顶
    2020-03-20
    private List<Map> getNoRoomList(List<Map> inspectRooms, List<Map> items) { boolean flag = false; List<Map> noInspectRoom = new ArrayList<>(); for (Map item: items) { for (Map inspectRoom: inspectRooms) { if (inspectRoom.get("project").equals(item.get("checkItem"))) { flag = true; break; } } if (!flag) { noInspectRoom.add(item); }else { flag = false; } } return noInspectRoom; } 我直接贴我写的处理代码吧,应该可以理解我的想法,这测试用例还真不好写。

    作者回复: private static List<Map> getNoRoomList(List<Map> inspectRooms, List<Map> items) { return items.stream().filter(item->inspectRooms.stream().noneMatch(inspectRoom->inspectRoom.get("project").equals(item.get("checkItem")))) .collect(Collectors.toList()); }

    
    4
  • 海拉鲁
    置顶
    2020-03-17
    为了写作业又去翻了《Java 8 实战》,测试终于通过了 public class MostPopularCollector implements Collector<Object, // 收集String流 Map<Object, Integer>, // 累加器是一个Map,key为字符,value为出现的次数 Optional> // 返回的是出现次数最多的字符 { /** * 返回一个在调用时创建的累加器 * @return */ public Supplier<Map<Object, Integer>> supplier() { return () -> new HashMap<>(); } /** * 定义收集流中数据逻辑 * @return */ public BiConsumer<Map<Object, Integer>, Object> accumulator() { return (Map<Object, Integer> acc, Object chart) -> acc.compute(chart, (key, val) -> val == null ? 1 : val + 1); // 如果当前字符未统计则统计为1,否则+1 } /** * 处理并行操作,其实就是将两个map合成一个,把value加起来 * @return */ public BinaryOperator<Map<Object, Integer>> combiner() { return (Map<Object, Integer> m1, Map<Object, Integer> m2) -> { Map<Object, Integer> all = new HashMap<>(m1); m2.forEach((chart, count) -> all.merge(chart, count, Integer::sum)); return all; }; } public Function<Map<Object, Integer>, Optional> finisher() { return (Map<Object, Integer> acc) -> Optional.ofNullable(acc.entrySet() .stream() .max(Map.Entry.comparingByValue()) .get().getKey()); } public Set<Characteristics> characteristics() { return Collections.unmodifiableSet(EnumSet.of(Characteristics.CONCURRENT)); } }
    展开

    作者回复: 👍🏻

    共 2 条评论
    11
  • Wiggle Wiggle
    置顶
    2020-03-17
    Stream API 有个 peek 方法可以接收一个 consumer 来打印数据,可以接在任意 transformation 操作后面查看数据

    作者回复: 是的,这是一种方法,此外IDEA已经增加了非常方便的Stream调试功能,可以参考https://www.jetbrains.com/help/idea/analyze-java-stream-operations.html

    
    8
  • Darren
    2020-03-17
    以前真没有特意去关注收集器,看了做了,参考了2片文章: https://www.cnblogs.com/yw0219/p/9589124.html https://my.oschina.net/piorcn/blog/424375 最终搞定,请老师指点 https://github.com/y645194203/geektime-java-100/blob/master/MostPopularCollector.java

    作者回复: 非常好

    
    8
  • pedro
    2020-03-17
    我目前想到的数据观察的方式比较原始,一种是通过log打印,一种是debug。但我肯定这都不是啥好办法,希望老师告知解放生产力的方法。

    作者回复: IDEA已经增加了非常方便的Stream调试功能,可以参考https://www.jetbrains.com/help/idea/analyze-java-stream-operations.html

    
    6
  • Demon.Lee
    2020-04-24
    每天晚上回去敲一点,花了好几个晚上,终于把这两节中的所有代码运行了一遍,只不过似懂非懂,还要继续练习。已经开始在工作中运用一些简单的了,读完这篇文章可能只需要20分钟,但把所有代码都练习一遍,就不是20分钟的事了,要持续学习才行。💪🏽

    作者回复: 还是需要自己想案例实际写一下代码

    共 2 条评论
    4
  • 汝林外史
    2020-03-19
    List<Map> l1,List<Map> l2,两个list,l1中有四个map,其中有key分别为1、2、3、4的四个字段,l2有两个map,其中有key分别为1,2的l1中一样的字段,怎么筛选最终得到一个list,只有key为3、4对应的两个map?写的比较乱,还请老师见谅,我想了下没想出来,最后for循环做的。

    作者回复: 把测试用例帖一下,不太明白l1和l2是啥。。。

    
    2
  • insight
    2020-03-18
    //各种转换,后面注释代表了输出结果 System.out.println(IntStream.of(1, 2).toArray().getClass()); //class [I System.out.println(Stream.of(1, 2).mapToInt(Integer::intValue).toArray().getClass()); //class [I System.out.println(IntStream.of(1, 2).boxed().toArray().getClass()); //class [Ljava.lang.Object; System.out.println(IntStream.of(1, 2).asDoubleStream().toArray().getClass()); //class [D System.out.println(IntStream.of(1, 2).asLongStream().toArray().getClass()); //class [J 老师,这一段代码的输出结果为什么是这样的呀?没看懂,求指教!

    作者回复: 看一下toArray的返回类型对比一下输出就知道了

    
    2
  • 鲁鸣
    2020-09-27
    在实际中,发现distinct需要根据元素类型的属性进行判断,这个时候就需要用别的方式了

    作者回复: https://stackoverflow.com/questions/23699371/java-8-distinct-by-property/27872852#27872852

    
    1
  • 大胖子呀、
    2020-05-20
    工作中遇到一个需求,计算运费:先从运费集合中找出同一个客户的数据,然后类似于累加数量(还有很多其他的逻辑)计算出运费(因为相同的客户数量超过一定数值会有优惠)。最后把计算出来的运费数据插入到数据库里。 我的做法是:以第一条数据的客户为基准,循环找出相同客户的数据,保存到一个新的集合中,同时从原数据集合里移除这条数据,最后计算出新集合里的运费就可以了。 感觉这种需求的话,好像就没办法用老师介绍的流方法来遍历计算了,因为不能删除数据,不知道我认为的是不是对的。 另外就我的实现来说,会不会出现问题?有没有更好的解决方案?

    作者回复: 按照客户直接进行分组聚合不是更简单

    共 3 条评论
    1