Map은 매핑 관계로 데이터를 저장하는 데 사용됩니다. Key - Value
Set의 경우 맨 아래 레이어는 실제로 여전히 Map이지만 Set은 Value, 즉 Value를 사용하지 않기로 선택합니다. Set의 값은 항상 상수입니다.
맵의 키와 값은 모든 유형의 데이터일 수 있으며 HashMap$Node 객체로 캡슐화됩니다.
맵의 키는 반복될 수 없지만 값은 반복될 수 있습니다. .동일한 Key가 있을 경우 등가 및 대체 연산이 수행됩니다
Map 키-값 쌍은 HashMap$Node
tab[i] = newNode(hash, key, value, null); -- Node<K,V> newNode(int hash, K key, V value, Node<K,V> next) { return new Node<>(hash, key, value, next); }
에 저장됩니다. 그러면 이 Node 노드의 데이터 유형은 무엇입니까?
소스 코드를 살펴보겠습니다. (Entry 인터페이스도 구현합니다.)
static class Node<K,V> implements Map.Entry<K,V> { final int hash; // 存放hash值 final K key; // 存放key值 V value; // 存放Value值 Node<K,V> next; // 存放下一个个节点,以形成链表结构 }
k-v 프로그래머의 탐색을 용이하게 하기 위해 EntrySet 컬렉션도 생성됩니다. 이 컬렉션에 저장된 요소 유형은 Entry이며, Entry 객체에는 k, v가 포함되어 있지만 기본적으로 여기의 k-v 값은 여전히 Node 노드의 데이터를 가리킵니다. 즉, 여기의 k-v는 여전히 주소 데이터를 저장합니다
// k-v存在有EntrySet的一个指向 Set set = map.entrySet(); System.out.println(set.getClass());
Output:
class java.util.HashMap$EntrySet
그럼 프로그래머 순회를 용이하게 하는 이 기능은 어떻게 반영되나요?
이유는 Map.Entry가 두 가지 매우 중요한 메소드인 K getKey(); V getValue();를 제공하기 때문입니다. 따라서 다음과 같은 방법으로 맵을 탐색할 수 있습니다.
Set set = map.entrySet(); System.out.println(set.getClass()); for (Object obj : set) { Map.Entry entry = (Map.Entry) obj; System.out.println(entry.getKey()); System.out.println(entry.getValue()); }
그러면 Entry에 저장된 k-v가 주소에 대한 포인터일 뿐이라는 것을 어떻게 증명할 수 있을까요? 매우 간단합니다
디버깅을 통해 먼저 Map에 저장된 데이터를 살펴보겠습니다. no2 키의 주소는 @727
다음으로 세트에 있는 no2 키의 주소를 살펴보겠습니다. 완전히 동일합니다:
코드 예:
Map map = new HashMap(); // 添加键值对 map.put("no1","dahe"); map.put("no2","zhangsan"); // Key重复会进行替换 map.put("no1","lisi"); System.out.println(map); // 根据键删除映射关系 map.remove("no1"); System.out.println(map); // 根据key得到值 Object no2 = map.get("no2"); System.out.println(no2); // 获取键值对数量 System.out.println(map.size()); // 判空 System.out.println(map.isEmpty()); // 清空 // map.clear(); // 查找键是否存在 System.out.println(map.containsKey("ok"));
첫 번째 공식: 모든 키를 꺼내고 키를 통해 해당 값을 가져옵니다
// 取出所有的key,通过key取出对应的value Set keySet = map.keySet(); for (Object o : keySet) { System.out.println(o); System.out.println(map.get(o)); }
두 번째 공식: 모든 값을 꺼냅니다
// 把所有的value值取出 Collection values = map.values(); for (Object value : values) { System.out.println(value); }
세 번째 공식: EntrySet을 통해 k-v
// 通过EntrySet来获取 k-v Set entrySet1 = map.entrySet(); for (Object o : entrySet1) { // 将entry 转成 Map.Entry Map.Entry m = (Map.Entry) o; System.out.println(m.getKey()); System.out.println(m.getValue()); }를 얻습니다.
위 내용은 Java 컬렉션 클래스에서 Map을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!