试图弄清楚如何有效地在我的代码中使用新的Java 8特性.stream()。
以下是我的代码
List<Item> list = db.query(sqlStatement, (rs, i) -> new Item(rs));
Map<String, List<Item>> itemsByName = new HashMap<>();
for (Item m : list) {
if (!itemsByName.containsKey(m.getName())) {
ArrayList<Item> items = new ArrayList<>();
items.add(m);
itemsByName.put(m.getName(), items);
} else {
itemsByName.get(m.getName()).add(m);
}
}
由此(1)
List<Item> list = db.query(sqlStatement, (rs, i) -> new Item(rs));
我得到的项目列表如下:
list(0):Name1:Value1
list(1):Name1:Value2
list(2):Name2:Value1
list(3):Name3:Value3
由此(2)
Map<String, List<Item>> itemsByName = new HashMap<>();
for (Item m : list) {
if (!itemsByName.containsKey(m.getName())) {
ArrayList<Item> items = new ArrayList<>();
items.add(m);
itemsByName.put(m.getName(), items);
} else {
itemsByName.get(m.getName()).add(m);
}
}
我想得到:
MapKey(Name1):列出{Name1:Value1,Name1:Value2}
MapKey(Name2):列出{Name2:Value1}
MapKey(Name3):列出{Name3:Value3}
如何使用stream()重写代码(2)以获得相同的结果?
答案 0 :(得分:5)
您似乎正在实施标准&#34; group by&#34;原始。 Streams API支持开箱即用:
Map<String, List<Item>> itemsByName =
list.stream().collect(Collectors.groupingBy(Item::getName));