inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

김영한의 실전 자바 - 중급 2편

list.sort() vs Collections.sort()

해결된 질문

219

won

작성한 질문수 3

0

강의 내용중 Comparable, Comparator 파트에서 List 데이터를 정렬할 때

  1. Collections.sort() 와 list.sort() 중 list.sort를 권장하는 이유를 조금 더 자세히 알고 싶습니다.

이 부분에서 list.sort()를 사용하는 게 더 객체지향적인 코드라고 말씀해주셨는데

List 인터페이스에 정의된 sort() 메서드를 사용하는 게 Collections class 에 정의된 static 메서드보다 어떤 측면에서 더 객체지향적인지 느낌은 오는데 이것 때문이다 라고 정리가 잘 안돼서 질문 드립니다.

 

  1. Collections 의 코드를 봤을 때 내부에서 Collections.sort(list, comparator)를 보게되면 list.sort(comparator) 메서드를 사용하고 있는데 그러면 굳이 Collections.sort()를 사용해야 할 케이스가 따로 있어서 정의한 것인지 어떤 경우에 사용하는지 궁금합니다.

 

public static <T> void sort(List<T> list, Comparator<? super T> c) {
    list.sort(c);
}

java 객체지향 코딩-테스트 알고리즘

답변 1

1

y2gcoder

안녕하세요. won님, 공식 서포터즈 y2gcoder입니다.

  1.  

말씀하셨던 것과 같이 Collections.sort(list);는 Collections 의 정적 메서드로 사용하고 있기 때문에 어떤 List 타입이든 사용할 수 있는 유연성이 있다고 볼 수 있습니다.

그와 비교해 list.sort()는 대상 객체가 스스로 정렬에 대한 책임을 가지고 있다는 점에서 더 객체지향적이라고 할 수 있습니다! 객체 지향 프로그래밍에서는 데이터와 데이터를 처리하는 메서드가 한 곳에 있는 것을 응집력 있다고 말합니다. 그래서 list.sort()의 경우에는 해당 인스턴스가 직접 데이터들에 대한 정렬 책임까지 지고 있기 때문에 응집력이 있는 객체 지향적인 코드라고 볼 수 있습니다 🙂

2.

말씀하신 것처럼 Collections.sort()의 내부 구현을 보면 결국 list.sort()를 호출하고 있기 때문에 결국 내부 구현은 같다고 볼 수 있습니다. 그래서 영한님도 새로 만드는 코드라면 list.sort() 를 사용하라고 추천해주신 것이라고 생각합니다 🙂

Collections.sort()를 사용한다면 아마도

  1. 기존 코드 베이스와의 통일성을 위해: 기존에 Collections 와 관련된 유틸 함수를 이미 많이 사용중 | Collections.sort()를 이미 많이 사용 중

  2. 기본 정렬 사용 시 코드가 더 깔끔해보여서:

Collections.sort(list);
list.sort(null); // null을 넣어줘야 함. 
  1. List가 아닌 자료구조를 정렬해야 할 때

Collections.sort(Arrays.asList(array)); //배열을 정렬할 때 사용

등에서 사용할 수 있을 것 같습니다!

 

감사합니다.

제네릭 타입 매개변수 제한과 관련한 문의입니다.

0

77

3

강의가 좀 버겁다 느껴질 때 학습방법 문의

1

129

4

제네릭 반환값 및 파라미터 선언 방식의 변화 <T> T

0

56

1

new T()가 안 되는 니유

0

95

1

안녕하세요, 문제와 실행 결과가 다른 부분이 있어 제보드립니다.

0

97

2

자바 로드맵 선택 질문

0

110

2

실전 자바 중급 - 2편 후 추천 강의

0

174

2

실프로젝트에서 Java25버전 사용

0

115

1

Arrays.sort

0

66

1

블로그 작성 시, 저작권 문제에 대하여

0

164

1

중급2편 56강의 bucket.add(value); 메서드가 이해가 안됩니다.

0

93

3

pop()과 poll()의 차이

0

94

1

특정 index의 노드 조회하기 질문

0

65

2

List.of() 비어있는 불변 리스트 생성

0

80

2

문제2: 개 타입 반환

0

52

2

[리뷰] 중급2편까지 겨우 완강 했습니다.

0

110

2

문제와 풀이1 Ex2와 Ex3

0

64

2

노드 삭제시 노드 null값으로 초기화

0

75

2

강의영상에 대한 질문

0

56

1

타입 매개변수 제한

0

59

1

compareTo

0

67

1

직접 구현하는 연결리스트 3 - 추가 부분 질문있습니다

0

95

3

섹션 8-58 equals and hashcode 에서 코드가 다르게 생성됨

0

68

2

퀴즈 오류 관련 문의

0

108

1