최근에 나는 변환 할 수있는 최적의 방법이 될 것이다 대해 동료와 대화를 List
에 Map
자바와 경우가 그렇게하는 특정 혜택을 제공합니다.
최적의 전환 접근 방식을 알고 싶습니다.
이 좋은 접근 방식입니까?
List<Object[]> results;
Map<Integer, String> resultsMap = new HashMap<Integer, String>();
for (Object[] o : results) {
resultsMap.put((Integer) o[0], (String) o[1]);
}
답변
List<Item> list;
Map<Key,Item> map = new HashMap<Key,Item>();
for (Item i : list) map.put(i.getKey(),i);
물론 각 Item getKey()
에 적절한 유형의 키를 반환하는 메서드 가 있다고 가정 합니다.
답변
와 자바 -8streams 및 Collectors
클래스를 사용하여 한 줄에이를 수행 할 수 있습니다 .
Map<String, Item> map =
list.stream().collect(Collectors.toMap(Item::getKey, item -> item));
짧은 데모 :
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
public class Test{
public static void main (String [] args){
List<Item> list = IntStream.rangeClosed(1, 4)
.mapToObj(Item::new)
.collect(Collectors.toList()); //[Item [i=1], Item [i=2], Item [i=3], Item [i=4]]
Map<String, Item> map =
list.stream().collect(Collectors.toMap(Item::getKey, item -> item));
map.forEach((k, v) -> System.out.println(k + " => " + v));
}
}
class Item {
private final int i;
public Item(int i){
this.i = i;
}
public String getKey(){
return "Key-"+i;
}
@Override
public String toString() {
return "Item [i=" + i + "]";
}
}
산출:
Key-1 => Item [i=1]
Key-2 => Item [i=2]
Key-3 => Item [i=3]
Key-4 => Item [i=4]
의견에서 언급했듯이 다소 명시 적으로 보이지만 Function.identity()
대신 대신 사용할 수 있습니다 .item -> item
i -> i
그리고 함수가 형용사가 아닌 경우 이진 연산자를 사용할 수 있습니다. 예를 들어 이것을 List
int 값의 경우 모듈로 3의 결과를 계산하는 매핑 함수를 고려해 봅시다 .
List<Integer> intList = Arrays.asList(1, 2, 3, 4, 5, 6);
Map<String, Integer> map =
intList.stream().collect(toMap(i -> String.valueOf(i % 3), i -> i));
이 코드를 실행하면 오류 메시지가 나타납니다 java.lang.IllegalStateException: Duplicate key 1
. 이는 1 % 3이 4 % 3과 같기 때문에 키 매핑 기능이 주어지면 동일한 키 값을 갖기 때문입니다. 이 경우 병합 연산자를 제공 할 수 있습니다.
다음은 값을 합한 것입니다. (i1, i2) -> i1 + i2;
메소드 참조로 대체 할 수 있습니다 Integer::sum
.
Map<String, Integer> map =
intList.stream().collect(toMap(i -> String.valueOf(i % 3),
i -> i,
Integer::sum));
이제 출력 :
0 => 9 (i.e 3 + 6)
1 => 5 (i.e 1 + 4)
2 => 7 (i.e 2 + 5)
그것이 도움이되기를 바랍니다! 🙂
답변
이 질문이 중복되지 않은 경우를 대비 하여 정답은 Google 컬렉션을 사용하는 것입니다 .
Map<String,Role> mappedRoles = Maps.uniqueIndex(yourList, new Function<Role,String>() {
public String apply(Role from) {
return from.getName(); // or something else
}});
답변
Java 8을 사용하면 다음을 수행 할 수 있습니다.
Map<Key, Value> result= results
.stream()
.collect(Collectors.toMap(Value::getName,Function.identity()));
Value
사용하는 모든 개체가 될 수 있습니다.
답변
Java 8부터 콜렉터를 사용한 @ZouZou 의 대답Collectors.toMap
은 확실히이 문제를 해결하는 관용적 방법입니다.
그리고 이것은 일반적인 작업이므로 정적 유틸리티로 만들 수 있습니다.
그렇게하면 솔루션이 진정으로 하나의 라이너가됩니다.
/**
* Returns a map where each entry is an item of {@code list} mapped by the
* key produced by applying {@code mapper} to the item.
*
* @param list the list to map
* @param mapper the function to produce the key from a list item
* @return the resulting map
* @throws IllegalStateException on duplicate key
*/
public static <K, T> Map<K, T> toMapBy(List<T> list,
Function<? super T, ? extends K> mapper) {
return list.stream().collect(Collectors.toMap(mapper, Function.identity()));
}
그리고 여기에 사용하는 방법이 있습니다 List<Student>
:
Map<Long, Student> studentsById = toMapBy(students, Student::getId);
답변
List
과는 Map
다른 개념이다. A List
는 주문한 항목 모음입니다. 항목에는 중복 항목이 포함될 수 있으며 항목에는 고유 식별자 (키) 개념이 없을 수 있습니다. A Map
에는 키에 매핑 된 값이 있습니다. 각 키는 하나의 값만 가리킬 수 있습니다.
따라서 귀하 List
의 항목 에 따라 로 변환하거나 변환하지 못할 수 있습니다 Map
. 님 List
의 항목에 중복 항목이 없습니까? 각 항목에 고유 키가 있습니까? 그렇다면을에 넣을 수 있습니다 Map
.
답변
Alexis는 이미 method를 사용하여 Java 8에 답변을 게시했습니다 toMap(keyMapper, valueMapper)
. 이 메소드 구현에 대한 doc 에 따라 :
리턴 된 맵의 유형, 변경 가능성, 직렬화 가능성 또는 스레드 안전성에 대한 보장은 없습니다.
따라서 Map
인터페이스 의 특정 구현에 관심이있는 경우 예 HashMap
를 들어 오버로드 된 형식을 다음과 같이 사용할 수 있습니다.
Map<String, Item> map2 =
itemList.stream().collect(Collectors.toMap(Item::getKey, //key for map
Function.identity(), // value for map
(o,n) -> o, // merge function in case of conflict with keys
HashMap::new)); // map factory - we want HashMap and not any Map implementation
사용 중 하나지만 Function.identity()
나하는 것은 i->i
괜찮지 만 보인다 Function.identity()
대신 i -> i
이 관련에 따라 일부 메모리 저장 힘 대답 .