작성
·
179
답변 1
2
안녕하세요. 나가을님
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
를 사용하는 것이 더 효율적일 수 있습니다.
감사합니다.