https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Global_Objects/Math/pow


쉽게 풀 수 있는 문제 였는데 집중을 안하면서 했더니 코드가 이상한대로 가고 있었다..  딴 짓하면서 코딩하면 안되겠다..


Map 컬렉션(Map<K, V>)

  Map 컬렉션은 (key)와 값(value)으로 구성된 객체를 저장하는 구조를 갖는다키는 중복으로 저장할 수 없고 값은 중복으로 저장할 수 있다.(동일한 key로 값을 추가하면 기존 key에 해당하는 값은 제거된다.) 따라서 Map 컬렉션은 (key)로 데이터를 관리한다. Map 컬렉션을 구현하는 대표적인 클래스들은 HashMap, Hashtable, LinkedHashMap, TreeMap 등이 있다. 공통적으로 사용되는 주요 메서드들은 put, get, remove, keySet 등이 있다.



 K와 V는 제네릭으로 K는 key 타입, V는 value 타입을 의미한다K와 V는 기본 자료형(int, double, boolean )은 사용할 수 없고 클래스나 인터페이스 타입만 사용이 가능하다.
 Map에 저장된 값을 가져오기 위해서는 get 메서드로 key 값을 입력하여 하나씩 가져오거나, keySet 및 entrySet 메서드를 이용하여 Set 컬렉션에 key 및 value를 저장하여 반복문을 통해 가져올 수 있다. 해당 내용에 대한 예제는 구현 클래스에서 알아보도록 하겠다.

HashMap

 HashMap은 Map 컬렉션의 대표적인 구현 클래스이다. HashMap을 생성하는 방법은 아래와 같다.



예제를 통해서 HashMap을 사용하는 방법에 대해서 간단히 알아보자.

import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; public class HashMapEx01 { public static void main(String[] args) { // key는 String 타입으로, value는 Integer 타입으로 지정 Map<String, Integer> hm = new HashMap<String, Integer>(); // put 메서드 이용 key와 value 추가 hm.put("A", 90); hm.put("B", 80); hm.put("C", 80); hm.put("D", 60); // size 메서드 이용 저장된 객체 수 출력 System.out.println("저장된 객체 수 : " + hm.size()); // get 메서드로 특정 key에 해당하는 값 출력 System.out.println("D의 값 : " + hm.get("D")); // 동일한 key로 추가(기존 내용 삭제) hm.put("C", 70); System.out.println("-------------------"); // keySet 메서드 이용 저장된 모든 key 값을 Set 컬렉션에 저장 Set<String> keys = hm.keySet(); // 반복자 생성 Iterator<String> it = keys.iterator(); while (it.hasNext()) { String key = it.next(); // Set의 key 값을 하나씩 key에 대입 int value = hm.get(key); // 해당 key에 해당하는 value 대입 / 오토 언박싱 System.out.println(key + " : " + value); } } }

 설명은 예제의 주석 부분을 참고하면 된다.

Hashtable

 Hashtable은 HashMap과 동일한 사용법을 갖는다. 차이점은 Hashtable은 동기화(synchronization)를 보장한다. 따라서 멀티 스레드에서는 Hashtable을 사용해야 하고, 단일 스레드에서는 HashMap을 사용하는 게 유리하다. Hashtable을 생성하는 방법은 아래와 같다.



 이번에는 Hashtable을 생성하고 entrySet 메서드를 이용하여 데이터를 출력하는 방법을 알아보자.

import java.util.Hashtable; import java.util.Iterator; import java.util.Map; import java.util.Map.Entry; import java.util.Set; public class HashtableEx01 { public static void main(String[] args) { Map<String, String> ht = new Hashtable<String, String>(); // key와 value값 저장 ht.put("사과", "Apple"); ht.put("복숭아", "Peach"); ht.put("망고스틴", "Mangosteen"); ht.put("석류", "Poemegranate"); ht.put("딸기", "Strawberries"); // entrySet 메서드 이용 Set 컬렉션에 key와 value 저장 Set<Entry<String, String>> fruits = ht.entrySet(); // 반복자 생성 Iterator<Entry<String, String>> it = fruits.iterator(); while (it.hasNext()) { Entry<String, String> entry = it.next(); String key = entry.getKey(); String value = entry.getValue(); System.out.println(key + " : " + value); } } }


+ Recent posts