我有以下地圖:
LonM =[0, 0, 0, 0, 46, 15]
LatM =[5, 52, 35, 16, 37, 5]
同時,我實作了一個復合模式類:
public class CompositeDataFrame implements IDataFrame, ICompositeDataFrame {
private String name;
private List <IDataFrame> children;
public CompositeDataFrame(String name){
this.name = name;
children = new LinkedList<>();
}
public void addChildren(IDataFrame child){
children.add(child);
}
我已經獲得了以下查詢方法:
public Map<Object, List<Object>> query(String keySelector, Predicate<Object> valuePredicate) {
Map<Object, List<Object>> result = new HashMap<>();
for (IDataFrame child:children)
result.putAll(child.query(keySelector, valuePredicate));
return result;
}
那么我們有以下主要呼叫查詢方法:
CompositeDataFrame comp = new CompositeDataFrame("CompositeCities");
CompositeDataFrame comp1 = new CompositeDataFrame("2");
comp.addChildren(comp1);
comp1.addChildren(df);
comp.addChildren(df);
System.out.println("\n" comp.query("LonM", entry -> ((Integer) entry) == 0));
問題是:如何連接每個孩子的地圖?
PD:我使用了 putAll 方法,但它洗掉了具有相同鍵的映射,因此在這種情況下它沒有用。
輸出應該是:
LonM =[0, 0, 0, 0, 0, 0, 0, 0] LatM =[5, 52, 35, 16, 5, 52, 35, 16]
非常感謝!
uj5u.com熱心網友回復:
是的,如果您使用putAll它會洗掉具有相同鍵的地圖條目。這就是地圖的作業原理。您正在尋找的是一種按鍵對所有條目進行分組的方法,這對于Streams來說有點容易。
Map<Object, List<Object>> result = children.stream()
// Map from Stream<IDataFrame> to Stream<Map.Entry<Object, List<Object>>>
.flatMap(child -> child.query(keySelector, predicate).entrySet().stream())
// Collect back into a Map<Object, List<Object>> using groupinBy
.collect(Collectors.groupingBy(
// Use the key to group the values
Map.Entry::getKey,
// Since we don't want a Map<Object, List<List<Object>>> the List needs to be flattend using Collectors.flatMapping.
Collectors.flatMapping(entry -> entry.getValue().stream(), Collectors.toList())));
當然,您不必使用Streams。
Map<Object, List<Object>> result = new HashMap<>();
for (IDataFrame child : children) {
// Loop over each entry of the query result.
child.query(keySelector, predicate).forEach((key, value) -> {
// computeIfAbsent creates a new List if none exists for the given key, otherwise it returns the existing one.
List<Object> valueList = result.computeIfAbsent(key, o -> new ArrayList<>());
// Finally just add all the values to the list.
valueList.addAll(value);
});
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/402970.html
標籤:
上一篇:如何避免單個派生類實作的虛函式?
下一篇:困難連接(SQL)
