linkedList는 deque 구현체입니까? 아니면 list 구현체입니까?
256
작성한 질문수 6
1. linkedList는 deque 구현체입니까? 아니면 list 구현체입니까?
만일 LIst 구현체인것도 있고 Deque구현체인것도 있으면
new LinkedList<>(); 했을때 부모로 덱과 리스트중 누구를 앞에 내세워야합니까?
강의에서 linkedList보다 ArrayList가 더 빠르다 하셨는데 그럼 LinkedList 를 쓰는 자리에는 ArrayDeque를 쓰는게 일반적입니까?
답변 1
4
안녕하세요. 나가을님
1. LinkedList는 Deque 구현체입니까? 아니면 List 구현체입니까?
- LinkedList는 자바에서 List와 Deque 둘 다의 구현체입니다. LinkedList 클래스는 List 인터페이스와 Deque 인터페이스를 동시에 구현하고 있습니다. 따라서 LinkedList 객체는 List와 Deque 둘 다의 성질을 가지고 있습니다.
2. 만일 List 구현체인 것도 있고 Deque 구현체인 것도 있으면 new LinkedList<>(); 했을 때 부모로 덱과 리스트 중 누구를 앞에 내세워야 합니까?
- 어떤 인터페이스를 앞에 내세울지는 사용 목적에 따라 다릅니다. List의 메서드만 필요하다면 List 인터페이스를 사용하고, Deque의 메서드가 필요하다면 Deque 인터페이스를 사용하는 것이 좋습니다. 예를 들어, 리스트의 기능만 필요하다면 다음과 같이 선언할 수 있습니다:
List<String> list = new LinkedList<>();반면, 덱의 기능이 필요하다면 다음과 같이 선언할 수 있습니다:
Deque<String> deque = new LinkedList<>();
3. 강의에서 LinkedList보다 ArrayList가 더 빠르다고 하셨는데 그럼 LinkedList를 쓰는 자리에는 ArrayDeque를 쓰는 게 일반적입니까?
강의에서 설명드린 것 처럼 일반적인 경우 ArrayDeque를 사용하시는 것이 성능면에서 유리할 수 있습니다.
요약하면, LinkedList는 List와 Deque 인터페이스를 모두 구현하고 있으며, 용도에 따라 적절한 인터페이스를 앞에 내세워야 합니다. 또한, 덱의 역할이 필요하다면 ArrayDeque를 사용하는 것이 더 효율적일 수 있습니다.
감사합니다.
제네릭 타입 매개변수 제한과 관련한 문의입니다.
0
80
3
강의가 좀 버겁다 느껴질 때 학습방법 문의
1
135
4
제네릭 반환값 및 파라미터 선언 방식의 변화 <T> T
0
63
1
new T()가 안 되는 니유
0
102
1
안녕하세요, 문제와 실행 결과가 다른 부분이 있어 제보드립니다.
0
98
2
자바 로드맵 선택 질문
0
111
2
실전 자바 중급 - 2편 후 추천 강의
0
177
2
실프로젝트에서 Java25버전 사용
0
121
1
Arrays.sort
0
68
1
블로그 작성 시, 저작권 문제에 대하여
0
166
1
중급2편 56강의 bucket.add(value); 메서드가 이해가 안됩니다.
0
94
3
pop()과 poll()의 차이
0
94
1
특정 index의 노드 조회하기 질문
0
66
2
List.of() 비어있는 불변 리스트 생성
0
81
2
문제2: 개 타입 반환
0
56
2
[리뷰] 중급2편까지 겨우 완강 했습니다.
0
114
2
문제와 풀이1 Ex2와 Ex3
0
65
2
노드 삭제시 노드 null값으로 초기화
0
78
2
강의영상에 대한 질문
0
57
1
타입 매개변수 제한
0
59
1
compareTo
0
68
1
직접 구현하는 연결리스트 3 - 추가 부분 질문있습니다
0
99
3
섹션 8-58 equals and hashcode 에서 코드가 다르게 생성됨
0
70
2
퀴즈 오류 관련 문의
0
109
1





