猿问

使用 Java 8 流进行分组

我正在和Java 8 Streams我一起上课,如下所示:


public class ShareDao {

    private String senderId;

    private String receiverId;


    public String getSenderId() {

        return senderId;

    }


    public String sharingMode(){

        return this.receiverId != null && !this.receiverId.trim().isEmpty() ? "incoming" : "outgoing";

    }

}

现在我想做的是,我想:


过滤掉 senderId 无效的记录(使用 Map<> 查找)

按 senderId 对集合进行分组,然后按 shareMode 对它们进一步分组。

下面是我的代码:


Map<String, Map<String, List<ShareDao>>> p = records.stream()

            .filter(shared -> userMap.containsKey(shared.getSenderId()))

            .collect(Collectors.groupingBy(ShareDao::getSenderId), Collectors.groupingBy(ShareDao::sharingMode, Function.identity()));

它向我抛出了错误:


错误:(105, 90) java: 没有找到适合 groupingBy(Share[...]gMode,java.util.function.Function) 方法的方法 java.util.stream.Collectors.groupingBy(java.util.function.Function ) 不适用(无法推断类型变量 T,K(实际参数列表和形式参数列表的长度不同))方法 java.util.stream.Collectors.groupingBy(java.util.function.Function,java.util. stream.Collector) 不适用(不存在类型变量 T 的实例,因此 java.util.function.Function 符合 java.util.stream.Collector)方法 java.util.stream.Collectors.groupingBy (java.util.function.Function,java.util.function.Supplier,java.util.stream.Collector) 不适用(无法推断类型变量 T、K、D、A、M(实际和正式参数列表的长度不同))


虽然Intellij Idea引发错误


Non-Static method cannot be referenced from static context


慕桂英546537
浏览 145回答 1
1回答

弑天下

基于你想要达到的目标过滤掉 senderId 无效的记录(使用 Map<>查找)按 senderId 对集合进行分组,然后按 shareMode 对它们进一步分组。您可以改为使用:Map<String,&nbsp;Map<String,&nbsp;List<ShareDao>>>&nbsp;p&nbsp;=&nbsp;records.stream() &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;.filter(shared&nbsp;->&nbsp;userMap.containsKey(shared.getSenderId()))&nbsp;//&nbsp;filter&nbsp;records &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;.collect(Collectors.groupingBy(ShareDao::getSenderId,&nbsp;//&nbsp;grouping&nbsp;by&nbsp;senderId &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Collectors.groupingBy(ShareDao::sharingMode)));&nbsp;&nbsp;//further&nbsp;grouping&nbsp;by&nbsp;sharingMode注意:groupingBy属性导致值聚合为List.中Collector定义的,collect因为它与您的尝试不同。
随时随地看视频慕课网APP

相关分类

Java
我要回答