Notice
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 안드로이드 유닛테스트란
- 안드로이드 os 구조
- 안드로이드 유닛 테스트 예시
- 안드로이드 레트로핏 사용법
- 스택 큐 차이
- android ar 개발
- 클래스
- 안드로이드 유닛 테스트
- 안드로이드 라이선스 종류
- ANR이란
- android retrofit login
- jvm 작동 원리
- 2022 플러터 설치
- 안드로이드 라이선스
- 플러터 설치 2022
- 안드로이드 레트로핏 crud
- 멤버변수
- 객체
- rxjava cold observable
- ar vr 차이
- 서비스 쓰레드 차이
- jvm이란
- 서비스 vs 쓰레드
- rxjava hot observable
- rxjava disposable
- Rxjava Observable
- 자바 다형성
- 2022 플러터 안드로이드 스튜디오
- 스택 자바 코드
- 큐 자바 코드
Archives
- Today
- Total
나만을 위한 블로그
[이펙티브 코틀린] 아이템 6. 사용자 정의 오류보다는 표준 오류를 사용하라 본문
728x90
반응형
require, check, assert 함수를 쓰면 대부분의 코틀린 오류를 처리할 수 있다. 하지만 이외에도 예측하지 못한 상황을 나타내야 하는 경우가 있다.
예를 들어 입력된 JSON 파일 형식에 문제가 있다면 JSONParsingException 등을 발생시키는 게 좋을 것이다.
inline fun <reified T> String.readObject(): T {
// ...
if (incorrectSign) {
throw JsonParsingException()
}
// ...
return result
}
표준 라이브러리에는 이를 나타내는 적절한 오류가 없으므로 사용자 정의 오류를 사용했다.
하지만 가능하다면 직접 오류를 정의하는 것보다 최대한 표준 라이브러리의 오류를 사용하는 게 좋다. 표준 라이브러리 오류는 많은 개발자가 알고 있으므로 이를 재사용하는 게 좋다.
잘 만들어진 규약을 가진 널리 알려진 요소를 재사용하면 다른 사람들이 API를 더 쉽게 배우고 이해할 수 있다. 일반적으로 쓰이는 예외를 몇 가지 정리하면 아래와 같다.
- IllegalArgumentException, IllegalStateException : 아이템 5에서 다뤘던 require, check를 써서 throw할 수 있는 예외
- IndexOutOfBoundsException : 인덱스 파라미터 값이 범위를 벗어났다는 걸 나타낸다. 일반적으로 컬렉션 or 배열과 같이 쓴다
- ConcurrentModificationException : 동시 수정(concurrent modification)을 금지했는데 발생했다는 걸 나타낸다
- UnsupportOperationException : 사용자가 사용하려고 했던 메서드가 현재 객체에선 사용할 수 없다는 걸 나타낸다. 기본적으로 사용할 수 없는 메서드는 클래스에 없는 게 좋다
- NoSuchElementException : 사용자가 사용하려고 했던 요소가 존재하지 않음을 나타낸다
반응형
'책 > Effective Kotlin' 카테고리의 다른 글
[이펙티브 코틀린] 아이템 8. 적절하게 null을 처리하라 (0) | 2022.05.29 |
---|---|
[이펙티브 코틀린] 아이템 7. 결과 부족이 발생할 경우 null, Failure를 사용하라 (0) | 2022.05.26 |
[이펙티브 코틀린] 아이템 5. 예외를 활용해 코드에 제한을 걸어라 (0) | 2022.05.22 |
[이펙티브 코틀린] 아이템 4. inferred 타입으로 리턴하지 마라 (0) | 2022.05.15 |
[이펙티브 코틀린] 아이템 3. 최대한 플랫폼 타입을 사용하지 마라 (0) | 2022.05.08 |
Comments