Создание вложенных карт с вложенными свойствами из списка, потока, Java 8
Я создал этот поток вопросов, создав список списков (вложенный список) с использованием forEach, Java 8
class EntityCompositeId {
private Long firstId;
private Long secondId;
// getter & setter...
}
class EntityComposite {
private EntityCompositeId id;
private String first;
private String second;
// getter & setter...
}
List<EntityComposite> listEntityComposite = ....
Supose this content
1, 1, "firstA", "secondBirdOne"
1, 2, "firstA", "secondBirdTwo"
1, 3, "firstA", "secondBirdThree"
2, 1, "firstB", "secondCatOne"
2, 2, "firstB", "secondCatTwo"
2, 3, "firstB", "secondCatThree"
3, 1, "firstC", "secondDogOne"
3, 2, "firstC", "secondDogTwo"
3, 3, "firstC", "secondDogThree"
Map<Long, Map<Long, String>> listOfLists = new HashMap<>();
Теперь с помощью потока я хочу заполнить как:
1 -> {1 ->"secondBirdOne", 2 -> "secondBirdTwo", 3 -> "secondBirdThree"}
2 -> {1 ->"secondCatOne", 2 -> "secondCatTwo", 3 -> "secondCatThree"}
3 -> {1 ->"secondDogOne", 2 -> "secondDogTwo", 3 -> "secondDogThree"}
Мой НЕ функциональный код был:
Map<Long, Map<Long, String>> listaMunDepa = listEntityComposite.stream()
.collect(Collectors.groupingBy(
e -> e.getId().getFirstId(),
Collectors.toMap(f -> f.getId().getSecondId(), Function.identity()))
);
вторая попытка
Map<Long, Map<Long, String>> listaMunDepa = listEntityComposite.stream()
.collect(Collectors.groupingBy(
e -> e.getId().getFirstId(),
Collectors.groupingBy(EntityComposite::getId::getSecondId, EntityComposite::getSecond)) // How change this line
);
1 ответ
Решение
Ты действительно близко, вместо того, чтобы пройти Function.identity
, ты должен пройти EntityComposite::getSecond
listEntityComposite.stream()
.collect(groupingBy(e -> e.getId().getFirstId(),
toMap(f -> f.getId().getSecondId(), EntityComposite::getSecond)));
потому что вы поставили Function.identity
результат был Map<Long, Map<Long, EntityComposite>>
так, как показано выше, вам просто нужно извлечь getSecondId
для valueMapper
функция предоставляется toMap
следовательно, давая Map<Long, Map<Long, String>>
,