책/Effective Kotlin

[이펙티브 코틀린] 아이템 42: compareTo의 규약을 지켜라

2023. 9. 4. 22:45
목차
  1. 1. compareTo의 동작원칙
  2. 2. compareTo의 대안
  3. 3. compareTo 구현하기
본문은 Effective Kotlin을 읽고 간단하게 정리한 글입니다. 필요에 따라 생략/수정된 부분이 있을 수 있으며, 내용이 추후 변경될 수 있습니다.

 

1. compareTo의 동작원칙

  • 비대칭적 동작: a >= b 이고, b >= a라면, a == b
  • 연속적 동작: a >= b이고, b >= c라면, a >= c
  • 코넥스적 동작: a >= b 또는 b >= a 중에 적어도 하나는 항상 true

 

 

2. compareTo의 대안

기본적으로 compareTo를 따로 정의해야 할 상황은 거의 없다. compareTo를 재정의하는 대신, 간단하게 다음의 함수를 이용해서 순서를 지정할 수 있다.

  • sortedBy: 하나의 프로퍼티를 기반으로 순서를 지정할 때 사용
  • sortedWith: 하나의 프로퍼티를 기반으로 순서를 지정할 때 사용
    • sortedWith 함수의 인자로는 Compartor<in T> 타입이 필요하다
    • compareBy 함수를 사용하면 간단하게 구현할 수 있다
// sortedBy - 단일 프로퍼티를 기반으로 정렬
val list = listOf("aaa", "cc", "bbbb")
val sorted = list.sortedBy { it.length }

println(list) // [aaa, cc, bbbb]
println(sorted) // [cc, aaa, bbbb]


// sortedWith - 복수 프로퍼티를 기반으로 정렬
val sortedDates = myDates.sortedWith(compareBy { it.month }.thenBy { it.day })
println(myDates)
/*
MyDate(month=8, day=19)
MyDate(month=5, day=16)
MyDate(month=1, day=29)
MyDate(month=5, day=10)
MyDate(month=8, day=3)
*/

println(sortedDates)
/*
MyDate(month=1, day=29)
MyDate(month=5, day=10)
MyDate(month=5, day=16)
MyDate(month=8, day=3)
MyDate(month=8, day=19)
*/

 

객체가 직접 Comparable<T> 인터페이스를 구현하는 형태로도 구현이 가능하다. 이때는 다음과 같은 규칙을 따른다.

  • 특정 프로퍼티를 기반으로 정렬하게끔 만든다
  • 비교에 대한 절대적인 기준이 없다면 비교하지 못하게 만든다
  • 자연스러운 순서를 갖는 객체(e.g. 측정단위, 날짜, 시간)인지 확실하지 않다면 비교기(comparator)를 사용하는 것이 좋다
    • 자주 사용한다면 클래스의 companion 객체로 정의할 수 있다
class User(val name: String, val surname: String) {
    // ...
    
    companion object {
        val DISPLAY_ORDER = compareBy(User::surname, User::name)
    }
}

val sorted = names.sortedWith(User.DISPLAY_ORDER)

 

 

3. compareTo 구현하기

compareTo는 다음과 같은 함수들을 통해 구현할 수 있다.

  • compareValues: 두 값을 단순하게 비교할 때 사용한다
class User(
    val name: String,
    val surname: String
): Comparable<User> {
    override fun compareTo(other: User): Int = 
                compareValues(surname, other.surname)
}
  • compareValuesBy: 더 많은 값을 비교하거나, 선택기(selector)를 활용해서 비교할 때 사용한다
class User(
    val name: String,
    val surname: String
): Comparable<User> {
    override fun compareTo(other: User): Int = 
                compareValuesBy(this, other, { it.suername }, { it.name })
}

 

저작자표시 비영리 (새창열림)

'책 > Effective Kotlin' 카테고리의 다른 글

[이펙티브 코틀린] 아이템 50: 컬렉션 처리 단계 수를 제한하라  (0) 2023.09.21
[이펙티브 코틀린] 아이템 43: API의 필수적이지 않은 부분을 확장 함수로 추출하라  (0) 2023.09.04
[이펙티브 코틀린] 아이템 21: 일반적인 프로퍼티 패턴은 프로퍼티 위임으로 만들어라  (0) 2023.08.02
[이펙티브 코틀린] 아이템17: 이름 있는 아규먼트를 사용하라  (0) 2023.07.23
[이펙티브 코틀린] 아이템16: 프로퍼티는 동작이 아니라 상태를 나타내야 한다  (0) 2023.07.21
  1. 1. compareTo의 동작원칙
  2. 2. compareTo의 대안
  3. 3. compareTo 구현하기
'책/Effective Kotlin' 카테고리의 다른 글
  • [이펙티브 코틀린] 아이템 50: 컬렉션 처리 단계 수를 제한하라
  • [이펙티브 코틀린] 아이템 43: API의 필수적이지 않은 부분을 확장 함수로 추출하라
  • [이펙티브 코틀린] 아이템 21: 일반적인 프로퍼티 패턴은 프로퍼티 위임으로 만들어라
  • [이펙티브 코틀린] 아이템17: 이름 있는 아규먼트를 사용하라
코택
코택
코택
TaxFree
코택
전체
오늘
어제
  • 분류 전체보기 (369)
    • Spring (29)
      • Spring (18)
      • 스프링 핵심 원리 - 고급편 (11)
    • Spring Batch (4)
    • JPA (4)
    • CS (89)
      • 자료구조 (2)
      • 네트워크 (5)
      • 운영체제 (1)
      • 데이터베이스 (4)
      • SQL (7)
      • 알고리즘 이론 (4)
      • 알고리즘 문제 풀이 (66)
    • 웹 (28)
      • React.js (4)
      • Next.js (1)
      • Node.js (14)
      • FastAPI (4)
      • Django (5)
    • 프로그래밍 언어 (45)
      • Python (5)
      • Java + Kotlin (29)
      • JavaScript + TypeScript (11)
    • 테스트코드 (26)
      • ATDD, 클린 코드 with Spring (4)
      • 이규원의 현실 세상의 TDD: 안정감을 주는 코드.. (20)
    • 인프라 (6)
      • AWS (2)
      • Kubernetes (4)
    • 트러블슈팅 (25)
    • 책 (89)
      • Effective Java (54)
      • Effective Kotlin (14)
      • 도메인 주도 개발 시작하기: DDD 핵심 개념 정.. (11)
      • 웹 프로그래머를 위한 데이터베이스를 지탱하는 기술 (6)
      • 도메인 주도 설계 첫걸음 (4)
    • Git (10)
    • 회고 (5)
    • etc (8)

블로그 메뉴

  • 홈
  • 방명록
  • 관리
  • GitHub
  • LinkedIn

공지사항

  • 스킨 관련

인기 글

태그

  • http
  • 깊이 우선 탐색
  • Shortest Path
  • fastapi
  • mysql
  • 그래프
  • 파이썬
  • BOJ
  • 그래프 탐색
  • Git
  • dp
  • 백준
  • 장고
  • atdd
  • 브루트포스

최근 댓글

최근 글

hELLO · Designed By 정상우.
코택
[이펙티브 코틀린] 아이템 42: compareTo의 규약을 지켜라
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.