반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 비전공자 git
- 케네스로그
- 미국유학생활
- 부산외대
- 개인 프로젝트 개발일지
- 2+2
- 미국대학생활
- 미국유학생
- CSUS
- Java 스터디
- 복수학위제도
- java
- 자바
- F1학생비자
- i-20
- 사이드프로젝트
- Kenneth Park
- 파이데이아창의인재학과
- 해외유학
- jpa
- 만다라트프로젝트
- 개발일지
- 유학생 준비물
- 자바 스터디
- 유학생대학생활
- 미국유학
- 미국대학
- JVM아키텍처
- 케네스
- California State University Sacramento
Archives
- Today
- Total
케네스로그
[자료구조/Java] ArrayList 본문
반응형
이전에 정적배열 Array에 대해 포스팅을 했었습니다. 이때, 정적배열의 단점은 최초에 선언한 사이즈를 나중에 변경이 불가능하다는 것이었죠.
이를 기억하면서 동적 배열을 알아보도록 하겠습니다.
동적배열 Dynamic Array
동적배열은 정적배열과 달리 배열의 크기가 가변적입니다. 다시 말해, 공간이 더 필요하면 늘릴 수 있다는 겁니다.
크기가 가변적인 동적배열은 여러 종류가 존재하지만, 대표적으로 ArrayList와 LinkedList가 존재합니다.
ArrayList
ArrayList는 배열을 동적으로 변화시키는 자료구조로써, List 인터페이스를 구현한 클래스입니다.
ArrayList의 선언과 사용
ArrayList<Character> arr = new ArrayList<>();
ArrayList를 사용하기 위해 ArrayList<타입> 변수명 = new ArrayList<>()의 형식으로 선언합니다.
⚙️컬렉션에서는 primitive 타입을 사용할 수 없다.
켈렉션에서는 변수의 타입이 사용자의 필요에 따라 정해짐으로, 일반(Generic)타입으로 설계되어 있다. 따라서 Integer, Double과 같은 Wrapper 클래스 객체를 사용해야만 한다.
기본적으로 메모리 상에서는 객체를 담을 수 있는 크기가 10인 배열이 생성됩니다. 데이터를 추가하게 되면 0번 인덱스부터 추가되며, 10을 초과하면 용량이 자동으로 증가됩니다.
ArrayList의 데이터 추가 및 삭제
ArrayList에서 중간 원소를 제거하게 되면, 제거된 원소의 뒷 원소들을 쉬프트(shift)하게 됩니다. 또한, 중간에 원소가 추가되면, 추가된 위치 뒤의 원소들이 모두 n번만큼 쉬프트(shift)하게 됩니다. 따라서 최악의 경우, 추가 또는 삭제에 O(n)만큼의 시간이 걸리게 되는거죠.
맨 마지막에 객체를 추가하는 경우, 그리고 인덱스를 이용해서 데이터를 탐색하는 일이 잦은 경우엔 적합한 자료구조입니다.
반응형
'Dev > 자료구조' 카테고리의 다른 글
[자료구조/Java] Hash 해시 (0) | 2022.01.21 |
---|---|
[자료구조/Java] LinkedList - 조회/추가/삭제 코드구현 (0) | 2022.01.21 |
[자료구조/Java] Stack (Java구현, 관련 메소드) (0) | 2022.01.02 |
[자료구조/Java] Queue (Java구현, 관련 메소드) (0) | 2021.12.28 |
[자료구조] 배열, 다차원배열 (1) | 2021.12.26 |