티스토리 뷰
🍏/Swift
[Swift] Structure > custom initializer를 추가해도 default, memberwise initializer 를 유지하는 방법
eungding 2022. 1. 8. 13:14728x90
반응형
Swift Docs의 Initialization 과 Extensions을 읽으며 알게 된 내용이다.
Swift의 Structure은 자동으로 default initializer와 memberwise initializer를 가지게 된다.
다만 custom initializer를 따로 정의하지 않았을 때만!!
예제를 통해 살펴보자.
struct Size {
var width = 0.0, height = 0.0
}
struct Point {
var x = 0.0, y = 0.0
}
struct Rect {
var origin = Point()
var size = Size()
}
let defaultRect = Rect()
let memberwiseRect = Rect(origin: Point(x: 2.0, y: 2.0),
size: Size(width: 5.0, height: 5.0))
Rect에 custom initializer 를 추가하게 되면
자동으로 제공되던 default initializer, memberwise initializer 를 개발자가 직접 구현해줘야한다는 것이다.
struct Size {
var width = 0.0, height = 0.0
}
struct Point {
var x = 0.0, y = 0.0
}
struct Rect {
var origin = Point()
var size = Size()
init() {}
init(origin: Point, size: Size) {
self.origin = origin
self.size = size
}
init(center: Point, size: Size) {
let originX = center.x - (size.width / 2)
let originY = center.y - (size.height / 2)
self.init(origin: Point(x: originX, y: originY), size: size)
}
}
let defaultRect = Rect()
let memberwiseRect = Rect(origin: Point(x: 2.0, y: 2.0),
size: Size(width: 5.0, height: 5.0))
let customRect = Rect(center: Point(x: 4.0, y: 4.0),
size: Size(width: 3.0, height: 3.0))
하지만 default initializer, memberwise initializer 자동생성을 그대로 유지하면서
custom initializer 를 추가하는 방법이 있는데, custom initializer 를 extension 에 작성하면 된다.
struct Size {
var width = 0.0, height = 0.0
}
struct Point {
var x = 0.0, y = 0.0
}
struct Rect {
var origin = Point()
var size = Size()
}
extension Rect {
init(center: Point, size: Size) {
let originX = center.x - (size.width / 2)
let originY = center.y - (size.height / 2)
self.init(origin: Point(x: originX, y: originY), size: size)
}
}
let defaultRect = Rect()
let memberwiseRect = Rect(origin: Point(x: 2.0, y: 2.0),
size: Size(width: 5.0, height: 5.0))
let customRect = Rect(center: Point(x: 4.0, y: 4.0),
size: Size(width: 3.0, height: 3.0))
이런 방법이 있는 줄 몰랐다!! 😮
하지만 나는 이니셜라이저는 extension이 아니라 original implementation 에 있는게 좋다고 생각한다.
+
외부 모듈에 있는 모델에 대해 커스텀 이니셜라이저를 추가한다고 할 때,
extension으로 커스텀 이니셜라이저를 작성할텐데 그 때 기존 구현이 깨지면 안되기 때문에
당연한 것 같기두..?
반응형
'🍏 > Swift' 카테고리의 다른 글
[Swift] Opaque Type vs Protocol Type (0) | 2022.01.23 |
---|---|
[Swift] Protocol Composition > One Class Type 포함가능 (0) | 2022.01.18 |
[Swift] Property Wrapper (0) | 2022.01.06 |
[Swift] Autoclosure 개념과 활용사례 (0) | 2021.12.30 |
[Swift] 함수 관련 혼용되는 용어 정리 (parameter name, argument label, argument value) (0) | 2021.12.26 |
댓글
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- Sketch 누끼
- Watch App for iOS App vs Watch App
- METAL
- flutter dynamic link
- DRF APIException
- flutter deep link
- Flutter 로딩
- flutter build mode
- Flutter Spacer
- Flutter Clipboard
- 플러터 싱글톤
- PencilKit
- Django Heroku Scheduler
- Flutter getter setter
- Python Type Hint
- 플러터 얼럿
- ribs
- Flutter Text Gradient
- Django FCM
- Dart Factory
- cocoapod
- ipad multitasking
- drf custom error
- github actions
- SerializerMethodField
- flutter 앱 출시
- 구글 Geocoding API
- 장고 Custom Management Command
- 장고 URL querystring
- Django Firebase Cloud Messaging
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함