List 컬렉션

 이전 포스팅에서 설명하였 듯이 List 컬렉션은 인덱스 순서로 저장이 되며, 중복된 데이터가 저장이 가능하다. 구조적으로 데이터를 일렬로 늘여놓는 구조를 갖는다. 객체(데이터 등)를 저장하면 인덱스가 자동으로 부여되고 부여된 인덱스를 통해 데이터의 검색 및 삭제가 가능하다.(인덱스에는 데이터가 저장되어 있는 참조 값을 갖는다.)  List 컬렉션을 구현하는 대표적인 클래스들은 ArrayList, Vector, LinkedList가 있다. List 인터페이스를 구현하는 클래스들이기 때문에 공통적으로 사용할 수 있는 메서드들이 많다. 기본적인 List의 메소드는 아래와 같다.


 ArrayList

 ArrayList는 List 인터페이스를 구현한 클래스이다설정된 저장 용량(capacity)보다 많은 데이터가 들어오면 자동으로 용량이 늘어난다. ArrayList를 생성하는 방법은 아래와 같다.

List<E> 객체명 = new ArrayList<E>([초기 저장용량]);

 초기 저장용량을 생략하면 기본적으로 10의 저장용량을 갖는다E는 제네릭 타입을 의미하는데 생략하면 Object 타입이 된다. Object는 모든 데이터 타입을 저장 가능하지만 데이터를 추가하거나 검색할 때 형 변환을 해야 한다. 자료구조에는 주로 동일한 데이터 타입을 저장하기 때문에 제네릭 타입을 지정하고 사용하는 것이 좋다. 기본적으로 데이터를 추가할 때는 인덱스 순으로 자동 저장된다. 이때 중간에 데이터를 추가하거나 삭제할 경우에는 인덱스가 한 칸씩 뒤로 밀리거나 당겨진다




import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class ArrayListEx01 { public static void main(String[] args) { List<String> list = new ArrayList<String>(); list.add("리스트1"); // 0번 index에 데이터 추가 list.add("리스트2"); // 1번 index에 데이터 추가 list.add("리스트3"); // 2번 index list.add("리스트4"); // 3번 index list.add(1, "리스트5"); // 1번 index에 데이터 추가(기존의 1번 이후의 인덱스들이 하나씩 뒤로 밀림) list.add("리스트6"); // 5번 index System.out.println(list.size()); // 저장된 데이터 용량 출력 : 6 System.out.println(list.get(0)); // 0번 index 값 출력 System.out.println(list.get(1)); // 1번 index 값 출력 System.out.println(); for (int i = 0; i < list.size(); i++) { // 반복문 이용 데이터 출력 System.out.println(i + "번 인덱스 데이터 : " + list.get(i)); } System.out.println(); list.remove(0); // 0번 index 삭제(하나씩 앞으로 당겨짐) list.remove("리스트5"); // 리스트5를 갖는 데이터 삭제(이후의 데이터들은 하나씩 앞으로 당겨짐) for (String value : list) { // for each 반복문 이용 데이터 출력 System.out.println(value); } System.out.println(); Iterator<String> elements = list.iterator(); // Iterator (반복자) while (elements.hasNext()) { // Iterator 이용 데이터 출력 / hasNext : 데이터가 있으면 true 없으면 false 리턴 System.out.println(elements.next()); // next() 다음 데이터 리턴 } } }

 아래 예제는 제네릭 타입을 클래스 타입으로 지정하고 데이터를 저장하고 갖고 오는 방법이다. 기본적인 방법은 똑같다.

class Avengers { // Avengers 클래스 정의 String name; // 필드 String id; int age; public Avengers(String name, String id, int age) { // 생성자 초기화 this.name = name; this.id = id; this.age = age; } } public class VectorEx01 { public static void main(String[] args) { List<Avengers> list = new ArrayList<Avengers>(); // ArrayList list.add(new Avengers("토니 스타크", "ironman", 53)); // 객체 생성 및 저장 list.add(new Avengers("피터 파커", "spiderman", 25)); list.add(new Avengers("브루스 배너", "Hulk", 50)); for (int i = 0; i < list.size(); i++) { // 반복문 Avengers av = list.get(i); System.out.println("이름 : " + av.name + "\n아이디 : " + av.id + "\n나이 : " + av.age); System.out.println("--------------------"); } } }

 처음 예제와 다른 점이라면 Avengers 자료형에 ArrayList의 인덱스에 저장된 참조값을 얻어오고, 해당 참조값으로 해당되는 객체의 데이터(name, id, age)를 구해와야 한다.


Vector

 ArrayList와 동일한 구조를 갖는다차이점이라면 Vector는 자동 동기화를 보장하므로 멀티 스레드 환경에서 안정적으로 사용이 가능하다하지만 단일 스레드에서는 ArrayList가 성능이 더 좋다. Vector를 생성하는 방법은 다음과 같다.

List<E> list = new Vector<e>([초기용량,</e> 증가용량]);

 초기용량과 증가용량을 생략하면 기본 값인 0으로 설정된다. 아래 예제는 키보드로 회원정보를 입력받고 데이터를 저장해 두었다가 출력하는 예제이다.

import java.util.List; import java.util.Scanner; import java.util.Vector; class MemberInfo{ private int no; private String name; private String phoneNumber; private String address; // getter(저장된 데이터를 리턴) / setter(필드값 세팅) 메소드 public int getNo() {return no;} public String getName() {return name;} public String getPhoneNumber() {return phoneNumber;} public String getAddress() {return address;} public void setNo(int no) {this.no = no;} public void setName(String name) {this.name = name;} public void setPhoneNumber(String phoneNumber) {this.phoneNumber = phoneNumber;} public void setAddress(String address) {this.address = address;} } public class VectorEx02 { public static void main(String[] args) { List<MemberInfo> list = new Vector<MemberInfo>(); do { Scanner sc = new Scanner(System.in); System.out.println("회원번호 입력"); int no = sc.nextInt(); System.out.println("이름 입력"); String name = sc.next(); System.out.println("핸드폰 번호 입력"); String phoneNumber = sc.next(); System.out.println("주소 입력"); String address = sc.next(); MemberInfo mm = new MemberInfo(); mm.setNo(no); // no 셋팅 mm.setName(name); // name 셋팅 mm.setPhoneNumber(phoneNumber); // phoneNumber 셋팅 mm.setAddress(address); // address 셋팅 list.add(mm); // list에 객체 저장 System.out.println("계속은 y, 아니면 아무키 입력"); String yn = sc.next(); if(yn.equals("y") || yn.equals("Y")){ continue; } else { break; } } while (true); for (int i = 0; i < list.size(); i++) { MemberInfo m = list.get(i); // list 인덱스에 저장된 객체의 참조값 저장 System.out.println("회원 번호 : " + m.getNo()); // 해당 데이터 출력 System.out.println("이름 : " + m.getName()); System.out.println("핸드폰 번호 : " + m.getPhoneNumber()); System.out.println("주소 : " + m.getAddress()); System.out.println("-------------------------------"); } } }
LinkedList

 List의 구현 클래스이므로 ArrayList나 Vector와 사용 방법은 동일하다하지만 구조는 다르게 구성되어 있다위의 컬렉션들은 인덱스로 데이터를 관리하지만 LinkedList는 인접한 곳을 링크하여 체인처럼 관리한다. LinkedList는 중간의 데이터를 삭제할 때 인접한 곳의 링크만을 변경하면 되기 때문에 중간에 데이터를 추가/삭제하는 경우 처리 속도가 빠르다차이점은 아래와 같다.

 상황에 따라 적절한 컬렉션을 사용하면 된다. LinkedList를 생성하는 방법은 아래와 같다.

List<E> list = new LinkedList<E>();



+ Recent posts