我正在和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"; }}現(xiàn)在我想做的是,我想:過濾掉 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(實際參數(shù)列表和形式參數(shù)列表的長度不同))方法 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(實際和正式參數(shù)列表的長度不同))雖然Intellij Idea引發(fā)錯誤Non-Static method cannot be referenced from static context
1 回答

弒天下
TA貢獻1818條經(jīng)驗 獲得超8個贊
基于你想要達到的目標
過濾掉 senderId 無效的記錄(使用 Map<>
查找)按 senderId 對集合進行分組,然后按 shareMode 對它們進一步分組。
您可以改為使用:
Map<String, Map<String, List<ShareDao>>> p = records.stream() .filter(shared -> userMap.containsKey(shared.getSenderId())) // filter records .collect(Collectors.groupingBy(ShareDao::getSenderId, // grouping by senderId Collectors.groupingBy(ShareDao::sharingMode))); //further grouping by sharingMode
注意:
groupingBy
屬性導致值聚合為List
.中
Collector
定義的,collect
因為它與您的嘗試不同。
添加回答
舉報
0/150
提交
取消