1. 열거형
- 유사한 종류의 여러 값을 한 곳에 모아서 정의한 것이다 예) 요일, 월, 계절 등
- enum 자체가 하나의 데이터 타입으로, 대문자 카멜케이스를 사용해 이름을 정의한다
- 각 case는 소문자 카멜케이스로 정의한다
- 각 case는 그 자체가 고유의 값이다(각 case에 자동으로 정수값이 할당되지 않음)
- 각 case는 한 줄에 개별로도, 한 줄에 여러개도 정의할 수 있다
enum 기본 형태
enum 이름 {
case 이름1
case 이름2
case 이름3, 이름4, 이름5
}
예시
enum BoostCamp {
case iosCamp
case androidCamp
case webCamp
}
2. 열거형 사용
- 타입이 명확할 경우, 열거형의 이름을 생략할 수 있다
- switch 구문에서 사용하면 좋다
enum Weekday {
case mon
case tue
case wed
case thu, fri, sat, sun
}
열거형 타입과 케이스를 모두 사용해도 된다
var day: Weekday = Weekday.mon
타입이 명확하다면 . 케이스처럼 표현해도 무방하다
day = .tue
print(day)
tue
switch의 비교값에 열거형 타입이 위치할 때 모든 열거형 케이스를 포함한다면 default를 작성할 필요가 없다
switch day {
case .mon, .tue, .wed, .thu:
print("평일입니다")
case Weekday.fri:
print("불금 파티!!")
case .sat, .sun:
print("신나는 주말!!")
}
3. rawValue (원시값)
- C언어의 enum처럼 정수값을 가질 수 있다
- rawValue는 case 별로 각각 다른 값을 가져야 한다
- 자동으로 1이 증가된 값이 할당된다
- rawValue를 반드시 지닐 필요가 없다면 굳이 만들지 않아도 된다
enum Fruit: Int {
case apple = 0
case grape = 1
case peach
case mango = 0 // 컴파일 오류
// mango와 apple의 원시값이 같으므로 mango 케이스의 원시값을 0으로 정의할 수 없다
}
print("Fruit.peach.rawValue == \(Fruit.peach.rawValue)")
Fruit.peach.rawValue == 2
정수 타입 뿐만 아니라, Hashable 프로토콜을 따르는 모든 타입을 원시값의 타입으로 지정할 수 있다
enum School: String {
case elementary = "초등"
case middle = "중등"
case high = "고등"
case university
}
print("School.middle.rawValue == \(School.middle.rawValue)")
School.middle.rawValue == 중등
4. 원시값을 통한 초기화
- rawValue를 통해 초기화할 수 있다
- rawValue가 case에 해당하지 않을 수 있으므로, rawValue를 통해 초기화 한 인스턴스는 옵셔널 타입이다
let apple: Fruit = Fruit(rawValue: 0) // 컴파일 오류
// rawValue를 통해 초기화 한 열거형 값은 옵셔널 타입이므로 Fruit 타입이 아니다
// 즉, 올바르게 작성하려면 아래같이 작성한다
let apple: Fruit? = Fruit(rawValue: 0)
if let 구문을 사용하면 rawValue에 해당하는 케이스를 곧바로 사용할 수 있다
if let orange: Fruit = Fruit(rawValue: 5) {
print("rawValue 5에 해당하는 케이스는 \(orange)입니다")
} else {
print("rawValue 5에 해당하는 케이스가 없습니다")
}
rawValue 5에 대항하는 케이스가 없다
5. 메소드
Swift의 열거형에는 메소드도 추가할 수 있습니다
enum Month {
case dec, jan, feb
case mar, apr, may
case jun, jul, aug
case sep, oct, nov
func printMessage() {
switch self {
case .mar, .apr, .may:
print("따스한 봄~")
case .jun, .jul, .aug:
print("여름 더워요~")
case .sep, .oct, .nov:
print("가을은 독서의 계절!")
case .dec, .jan, .feb:
print("추운 겨울입니다")
}
}
}
Month.mar.printMessage()
따스한 봄~
정리
1. 열거형
- 유사한 종류의 여러 값을 한 곳에 모아서 정의한 것
- enum 자체가 하나의 데이터 타입으로, 대문자 카멜케이스를 사용해 이름을 정의한다
- 각 case는 소문자 카멜케이스로 정의
- 각 case는 그 자체가 고유의 값이다 (각 case에 자동으로 정수 값이 할당되지 않는다)
- 각 case는 한 줄에 개별로도, 한 줄에 여러 개도 정의할 수 있다
enum 이름 {
case 이름1
case 이름2
case 이름3, 이름4, 이름 5
// ...
}
2. 열거형 사용
- 타입이 명확할 경우, 열거형의 이름을 생략할 수 있다
- switch 구문에서 사용하기 좋다
- 열거형 타입과 케이스를 모두 사용해도 된다
- 타입이 명확하다면 . 케이스 처럼 표현해도 무방하다
- switch의 비교값에 열거형 타입이 위치할 때 모든 열거형 케이스를 포함한다면 default를 작성하지 않아도 된다
3. rawValue (원시값)
- C언어 enum 처럼 정수값을 가질 수 있다
- rawValue는 case별로 각각 다른 값을 가져야 한다
- 자동으로 1이 증가된 값이 할당된다
- rawValue를 반드시 지닐 필요가 없다면 굳이 만들지 않아도 된다
- 정수 타입 뿐만 아니라, Hashable 프로토콜을 따르는 모든 타입을 원시값의 타입으로 지정할 수 있다
- 열거형 원시값 타입이 String일 때, 원시값이 지정되지 않았다면 case의 이름을 원시값으로 사용한다
4. 원시값을 통한 초기화
- rawValue를 통해 초기화할 수 있다
- rawValue가 case에 해당하지 않을 수 있으므로, rawValue를 통해 초기화 한 인스턴스는 옵셔널 타입이다
- rawValue를 통해 초기한 열거형 값은 옵셔널 타입이다
- if let 구문을 사용하면 rawValue에 해당하는 케이스를 곧바로 사용할 수 있다
5. 메소드
- Swift의 열거형에는 메소드도 추가할 수 있다
2022.02.23 - [Study/Swift_BoostCourse_Basic] - iOS 프로그래밍을 위한 스위프트 기초
iOS 프로그래밍을 위한 스위프트 기초
다음과 같이 연재되는 포스트는 부스트코스에서 야곰님의 'iOS 프로그래밍을 위한 스위프트 기초' 강좌를 수강한 후 작성한 기록입니다. 부스트코스에서 야곰님의 'iOS 프로그래밍을 위한 스위프
jjudy99.tistory.com
'[Non-Updated] iOS > Swift_BoostCourse_Basic' 카테고리의 다른 글
[Swift_BoostCourse_Basic] CH 2_14. 클래스 (0) | 2022.03.08 |
---|---|
[Swift_BoostCourse_Basic] CH 2_13. 구조체 (0) | 2022.03.08 |
[Swift_BoostCourse_Basic] CH 1_Quiz 1 (0) | 2022.03.08 |
[Swift_BoostCourse_Basic] CH 1_12. 옵셔널 추출 (0) | 2022.03.08 |
[Swift_BoostCourse_Basic] CH 1_11. 옵셔널 (0) | 2022.03.03 |