일반적으로 Map은 키-값 쌍으로 구성된 데이터 구조이며 각 키는 컬렉션에서 고유합니다. Java에서 Map에 관한 9가지 주요 이슈를 설명하기 위해 K와 V를 사용하여 키와 값을 표현해 보겠습니다.
0. Map을 List 유형으로 변환
Java에서 Map 인터페이스는 키 세트, 값 세트, 키-값 세트의 세 가지 컬렉션 획득 방법을 제공합니다. 이들은 모두 생성자 또는 addAll() 메소드를 통해 List 유형으로 변환될 수 있습니다. 다음 코드는 맵에서 ArrayList를 구성하는 방법을 보여줍니다.
// key list List keyList = new ArrayList(map.keySet()); // value list List valueList = new ArrayList(map.valueSet()); // key-value list List entryList = new ArrayList(map.entrySet());
1. 항목을 통해 맵 탐색
Java에서 이러한 키-값 쌍으로 존재하는 방식을 지도. Map.entrySet()은 매우 효율적인 순회 방법인 키-값 세트를 반환합니다.
for(Entry entry: map.entrySet()) { // get key K key = entry.getKey(); // get value V value = entry.getValue(); }
Iterator 특히 JDK1.5 이전에는 자주 사용합니다.
Iterator itr = map.entrySet().iterator(); while(itr.hasNext()) { Entry entry = itr.next(); // get key K key = entry.getKey(); // get value V value = entry.getValue(); }
2. 정렬은 자주 필요합니다. 한 가지 방법은 비교기를 통해 구현하는 것입니다:
List list = new ArrayList(map.entrySet()); Collections.sort(list, new Comparator() { @Override public int compare(Entry e1, Entry e2) { return e1.getKey().compareTo(e2.getKey()); } });
SortedMap sortedMap = new TreeMap(new Comparator() { @Override public int compare(K k1, K k2) { return k1.compareTo(k2); } }); sortedMap.putAll(map);
코드는 다음과 같습니다.
List list = new ArrayList(map.entrySet()); Collections.sort(list, new Comparator() { @Override public int compare(Entry e1, Entry e2) { return e1.getValue().compareTo(e2.getValue()); } });
Test1에서는 map이 정적이라고 선언했지만 Test1.map.put(3,"3")처럼 초기화 중에 해당 값을 변경할 수 있습니다.
Test2에서는 내부 클래스를 전달하고 수정할 수 없도록 설정한 다음 Test2.map.put(3, "3")을 실행하면
UnsupportedOperationException 异常来禁止你修改。 public class Test1 { private static final Map map; static { map = new HashMap(); map.put(1, "one"); map.put(2, "two"); } } public class Test2 { private static final Map map; static { Map aMap = new HashMap(); aMap.put(1, "one"); aMap.put(2, "two"); map = Collections.unmodifiableMap(aMap); } }
가 발생합니다. 5. HashMap, TreeMap 및 Hashtable의 차이점
Map 인터페이스에는 HashMap, TreeMap 및 Hashtable의 세 가지 구현이 있습니다.
자세한 내용은 "HashMap vs. TreeMap vs. Hashtable vs. LinkedHashMap" 기사를 참조하세요.
Map에 키-값 쌍을 추가하면 키와 값 사이에 일대일 대응이 있음을 의미합니다. Map이며 하나의 키는 하나의 값에 해당합니다. 그러나 때로는 특정 값을 통해 키를 찾는 등의 역방향 쿼리가 필요할 때도 있습니다. 이러한 데이터 구조를 양방향 맵이라고 합니다. 안타깝게도 JDK에서는 이를 지원하지 않습니다.
Apache와 Guava는 이러한 양방향 맵 구현을 공동으로 제공합니다. 구현에서는 키와 값이 모두 1:1 관계를 가져야 한다고 규정합니다.
Java는 맵을 복사하는 다양한 방법을 제공하지만 이러한 방법이 항상 동기화되는 것은 아닙니다. 간단히 말해서, 지도가 변경되더라도 복사된 지도는 그대로 유지됩니다. 다음은 보다 효율적인 구현 방법입니다.
Map CopyMap = Collections.synchronizedMap(map)
물론 복제라는 또 다른 방법도 있습니다. 그러나 Java 창시자인 Josh Bloch는 맵 복제 문제에 대한 인터뷰에서 다음과 같이 말한 적이 있습니다. 복제 방법은 사람들이 실제로 필요하기 때문에 많은 클래스에서 제공됩니다. 그러나 복제는 매우 제한적이며 많은 경우 불필요한 효과를 초래합니다.
8. 빈 지도 만들기
이 지도를 사용할 수 없도록 설정한 경우 다음
map = Collections.emptyMap();
을 통해 얻을 수 있습니다. , 직접
map = new HashMap();