[英]Java8 Lambda compare two List and trasform to Map
假設我有兩個 class:
class Key {
private Integer id;
private String key;
}
class Value {
private Integer id;
private Integer key_id;
private String value;
}
現在我填寫第一個列表如下:
List<Key> keys = new ArrayLisy<>();
keys.add(new Key(1, "Name"));
keys.add(new Key(2, "Surname"));
keys.add(new Key(3, "Address"));
第二個:
List<Value> values = new ArrayLisy<>();
values.add(new Value(1, 1, "Mark"));
values.add(new Value(2, 3, "Fifth Avenue"));
values.add(new Value(3, 2, "Fischer"));
你能告訴我如何重寫以下代碼:
for (Key k : keys) {
for (Value v : values) {
if (k.getId().equals(v.getKey_Id())) {
map.put(k.getKey(), v.getValue());
break;
}
}
}
使用 Lambda?
謝謝!
- - - -更新 - - - -
是的,它確實有效,我忘記了第一篇文章中的“使用 Lambdas”(現在我添加了)。 我想用 Lamdas 重寫兩個嵌套for
cicle。
以下是使用流的方法。
Map<String, String> results = keys.stream()
.flatMap(k -> IntStream.range(0, values.size())
.filter(i -> k.getId() == values.get(i).getKey_id())
.mapToObj(i -> new AbstractMap.SimpleEntry<>(
k.getKey(), values.get(i).getValue())))
.collect(Collectors.toMap(Entry::getKey, Entry::getValue));
results.entrySet().forEach(System.out::println);
印刷
Address=Fifth Avenue
Surname=Fischer
Name=Mark
Imo,你的方式更清晰,更容易理解。 Streams/w lambdas 或方法引用並不總是最好的方法。
也可以考慮采用混合方法。
(isPresent)
添加到 map。Map<String,String> map = new HashMap<>();
for (Key k : keys) {
Optional<Value> opt = values.stream()
.filter(v -> k.getId() == v.getKey_id())
.findFirst();
if (opt.isPresent()) {
map.put(k.getKey(), opt.get().getValue());
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.