Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 클린 코드
- combine
- ribs
- SWIFT
- Observable
- map
- uiscrollview
- UITextView
- ios
- swift documentation
- swiftUI
- UICollectionView
- MVVM
- uitableview
- collectionview
- 리팩토링
- RxCocoa
- rxswift
- Xcode
- 리펙토링
- clean architecture
- 스위프트
- 리펙터링
- HIG
- Clean Code
- Refactoring
- Human interface guide
- 애니메이션
- Protocol
- tableView
Archives
- Today
- Total
김종권의 iOS 앱 개발 알아가기
[iOS - swift] Result 타입 (성공, 실패) 본문
Result 타입
- 성공과 실패에 대한 결과값을 반환하고 싶은 경우 사용
- Result 타입은 enum이며 두 개의 제네릭한 결과를 리턴하는 것이며, Failure 제네릭은 Error를 상속받은 타입이어야 함
- Success는 Value type인 (Void, String, Int)등을 사용하도 되지만 Failure는 Error를 상속받은 자료형으로 채워주어야 가능
Result 타입 사용
- Success 타입 정의 (옵셔널)
struct Response {
let message: String = "success!"
}
- Failure 타입 정의 (필수)
enum MyErrorType: Error {
case limited
case abuse
}
- Result 타입을 리턴하는 함수 정의
func requestAPI(count: Int) -> Result<Response, MyErrorType> {
switch count {
case 0...3:
return .success(Response())
case 4...100:
return .failure(.limited)
default:
return .failure(.abuse)
}
}
- 위 함수를 사용하는 형태 - switch case문을 이용하며 두 가지 케이스로 나누어 활용
let result = requestAPI(count: 3)
switch result {
case .success(let response):
print(response)
case .failure(let error):
print(error)
}
'iOS 기본 (swift)' 카테고리의 다른 글
[iOS - swift] for, stride, Range (0) | 2021.03.03 |
---|---|
[iOS - swift] 고차함수map(map, flatMap, compactMap), filter, reduce (0) | 2021.02.28 |
[iOS - swift] property 구분 방법 (stored property, computed property, lazy property) (0) | 2021.02.25 |
[iOS - swift] switch와 where을 같이 사용하는 방법 (0) | 2021.02.25 |
[iOS - swift] print vs NSLog (0) | 2021.02.24 |
Comments