Java/Java 문법

[JAVA] 컬렉션 프레임워크 개념(List, Set, Map)

민돌v 2021. 4. 28. 16:58

1. 자바 컬렉션 프레임 워크란

- 자바에서 컬렉션 프레임워크(Collection Framwork)란 다수의 데이터를 쉽고 효과적으로 처리할 수 있는 표준화된 방법을 제공하는 클래스의 집합니다.

- 쉽게말해, 데이터를 저장하는 자료 구조와 데이터를 처리하는 알고리즘을 구조화하여 클래스로 구현해 놓은 일종의 인터페이스로 볼 수 있습니다.

 

2. 컬렉션 프레임워크 주요 인터페이스

컬렉션 프레임워크에서는 데이터를 저장하는 자료 구조에 따라 다음과 같은 핵심이 되는 주요 인터페이스를 정의하고 있습니다.

 

1. List 인터페이스

2. Set 인터페이스

3. Map 인터페이스

구조상의 차이로 List와 Set / Map을 별도로 정의하긴 합니다.

그림으로 그 차이를 보면 이렇습니다.

3. 주요 인터페이스의 간략한 특징

자바에서 컬렉션 프레임워크를 구성하고 있는 주요 인터페이스의 간략한 특징은 다음과 같습니다.

인터페이스

설명

구현 클래스

List<E>

순서가 있는 데이터의 집합으로, 데이터의 중복을 허용함.

Vector, ArrayList, LinkedList, Stack, Queue

Set<E>

순서가 없는 데이터의 집합으로, 데이터의 중복을 허용하지 않음.

HashSet, TreeSet

Map<K, V>

키와 값의 한 쌍으로 이루어지는 데이터의 집합으로, 순서가 없음.

이때 키는 중복을 허용하지 않지만, 값은 중복될 수 있음.

HashMap, TreeMap, Hashtable, Properties

4. Collection 인터페이스

List와 Set 인터페이스의 많은 공통된 부분을 Collection 인터페이스에서 정의하고, 두 인터페이스는 그것을 상속받습니다.

따라서 Collection 인터페이스는 컬렉션을 다루는데 가장 기본적인 동작들을 정의하고, 그것을 메소드로 제공하고 있습니다.

 

Collection 인터페이스에서 제공하는 주요 메소드는 다음과 같습니다.

메소드

설명

boolean add(E e)

해당 컬렉션(collection)에 전달된 요소를 추가함. (선택적 기능)

void clear()

해당 컬렉션의 모든 요소를 제거함. (선택적 기능)

boolean contains(Object o)

해당 컬렉션이 전달된 객체를 포함하고 있는지를 확인함.

boolean equals(Object o)

해당 컬렉션과 전달된 객체가 같은지를 확인함.

boolean isEmpty()

해당 컬렉션이 비어있는지를 확인함.

Iterator<E> iterator()

해당 컬렉션의 반복자(iterator)를 반환함.

boolean remove(Object o)

해당 컬렉션에서 전달된 객체를 제거함. (선택적 기능)

int size()

해당 컬렉션의 요소의 총 개수를 반환함.

Object[] toArray()

해당 컬렉션의 모든 요소를 Object 타입의 배열로 반환함.