HashMap은 for문으로 요소를 순회할 때 정렬되지 않은 순서로 순회합니다. 이 글에서는 정렬된 순서로 Map, HashMap을 순회하는 방법을 소개합니다.
1. Map.Entry 리스트를 정렬하여 순회
HashMap.entrySet()
은 Map의 요소를 Entry 객체로 Set에 저장하고 리턴합니다.
리턴된 Set은 ArrayList 생성자의 인자로 전달하여 리스트로 만들 수 있습니다.
이렇게 만들어진 리스트를 sort()
로 정렬하고 for문으로 순회할 수 있습니다. 아래 예제에서는 Key를 기준으로 오름차순 정렬하였습니다.
import java.util.*;
public class Example1 {
public static void main(String[] args) {
Map<String, Integer> map = new HashMap<>();
map.put("apple", 400);
map.put("kiwi", 200);
map.put("grape", 300);
map.put("banana", 150);
List<Map.Entry<String, Integer>> entries = new ArrayList<>(map.entrySet());
entries.sort(Comparator.comparing(Map.Entry::getKey));
entries.forEach(System.out::println);
}
}
Output:
apple=400
banana=150
grape=300
kiwi=200
만약 value를 기준으로 정렬하고 싶을 때는, comparing(Map.Entry::getValue)
와 같이 구현할 수 있습니다.
entries.sort(Comparator.comparing(Map.Entry::getValue));
2. Stream으로 정렬 및 순회
아래 예제와 같이 Map의 EntrySet을 Stream으로 만들고, Stream에서 정렬하고 순회할 수 있습니다.
import java.util.*;
public class Example2 {
public static void main(String[] args) {
Map<String, Integer> map = new HashMap<>();
map.put("apple", 400);
map.put("kiwi", 200);
map.put("grape", 300);
map.put("banana", 150);
map.entrySet().stream().sorted(Comparator.comparing(Map.Entry::getKey))
.forEach(System.out::println);
}
}
Output:
apple=400
banana=150
grape=300
kiwi=200
3. TreeMap으로 정렬 및 순회
TreeMap은 입력 순서가 유지되는 자료구조입니다. 즉, 모든 요소를 순회할 때 요소가 입력된 순서대로 순회합니다.
만약 데이터를 정렬한 뒤에 Map에 저장해야 할 때는 TreeMap을 사용할 수 있습니다. 정렬된 순서로 요소가 저장되기 때문에 순회할 때 Map을 정렬할 필요 없이 반복문으로 순회하면 됩니다.
import java.util.Map;
import java.util.TreeMap;
public class Example {
public static void main(String[] args) {
Map<String, Integer> map = new TreeMap<>();
map.put("apple", 400);
map.put("kiwi", 200);
map.put("grape", 300);
map.put("banana", 150);
map.entrySet().forEach(System.out::println);
}
}
Output:
apple=400
banana=150
grape=300
kiwi=200
Loading script...
Related Posts
- Java - Unsupported class file major version 61 에러
- Java - String.matches()로 문자열 패턴 확인 및 다양한 예제 소개
- Java - 문자열 공백제거 (trim, replace)
- Java - replace()와 replaceAll()의 차이점
- Java - ArrayList 초기화, 4가지 방법
- Java - 배열 정렬(Sorting) (오름차순, 내림차순)
- Java - 문자열(String)을 비교하는 방법 (==, equals, compare)
- Java - StringBuilder 사용 방법, 예제
- Java - 로그 출력, 파일 저장 방법 (Logger 라이브러리)
- Java IllegalArgumentException 의미, 발생 이유
- Java - NullPointerException 원인, 해결 방법
- Seleninum의 ConnectionFailedException: Unable to establish websocket connection 해결
- Java - compareTo(), 객체 크기 비교
- Java - BufferedWriter로 파일 쓰기
- Java - BufferedReader로 파일 읽기
- Java charAt() 함수 알아보기
- Java - BigInteger 범위, 비교, 연산, 형변환
- Java contains()로 문자(대소문자 X) 포함 확인
- Java - Set(HashSet)를 배열로 변환
- Java - 문자열 첫번째 문자, 마지막 문자 확인
- Java - 문자열 한글자씩 자르기
- Java - 문자열 단어 개수 가져오기
- Java - 1초마다 반복 실행
- Java - 배열을 Set(HashSet)로 변환
- Java - 여러 Set(HashSet) 합치기
- Java - 명령행 인자 입력 받기
- Java - 리스트 역순으로 순회, 3가지 방법
- Java - 특정 조건으로 리스트 필터링, 3가지 방법
- Java - HashMap 모든 요소들의 합계, 평균 계산
- Java - 특정 조건으로 HashMap 필터링
- Java - 싱글톤(Singleton) 패턴 구현
- Java - 숫자 왼쪽에 0으로 채우기
- Java - String 배열 초기화 방법
- Java - 정렬된 순서로 Map(HashMap) 순회
- Java - HashMap에서 key, value 가져오기