HashMap

iy·2024년 1월 14일
0

Java-CollectionFramework

목록 보기
7/7

HashMap과 HashTable

  • 순서X, 중복(키X, 값O)
  • Map인터페이스를 구현, 데이터를 키와 값의 쌍으로 저장
  • HashMap(동기화X)은 HashTable(동기화O)의 신버젼

HashMap

  • Map인터페이스를 구현한 대표적인 컬렉션 클래스
  • 순서를 유지하려면 LinkedHashMap클래스를 사용하면 된다.

TreeMap

  • 범위 검색과 정렬에 유리한 컬렉션 클래스
  • HashMap보다 데이터 추가, 삭제에 시간이 더 걸림

HashMap의 키와 값

  • 해싱 기법으로 데이터를 저장, 데이터가 많아도 검색이 빠르다.
  • Map 인터페이스를구현, 데이터를 키와 값의 쌍으로 저장

키(key) : 컬렉션 내의 키(key)중에서 유일해야 함
값(value) : 키와 달리 데이터의 중복을 허용함

HashMap map = new HashMap();

map.put("myId", "1234");
map.put("asdf", "1111");
map.put("asdf", "1234");
myId1234
asdf1234

Hashing 원리

  • 해시함수(hash function)로 해시테이블(hash table)에 데이터를 저장, 검색
  • 해시테이블은 배열과 링크드 리스트가 조합된 형태(데이터가 저장되어 있는 곳)

해시테이블에 저장된 데이터를 가져오는 과정
1. 키로 해시함수를 호출해서 해시코드를 얻는다.
2. 해시코드(해시함수의 반환값)에 대응하는 링크드리스트를 배열에서 찾는다.
3. 링크드리스트에서 키와 일치하는 데이터를 찾는다.
※ 해시함수는 같은 키에 대해 항상 같은 해시코드를 반환해야 한다.
서로 다른 키일지라도 같은 값의 해시코드를 반환할 수도 있다.


👀 참고
자바의정석
자바의정석

0개의 댓글