일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 리펙터링
- map
- uitableview
- Observable
- ribs
- clean architecture
- 리펙토링
- combine
- Xcode
- 클린 코드
- UITextView
- Protocol
- 리팩토링
- RxCocoa
- swiftUI
- 애니메이션
- ios
- 스위프트
- rxswift
- Human interface guide
- tableView
- collectionview
- SWIFT
- MVVM
- Clean Code
- HIG
- swift documentation
- Refactoring
- UICollectionView
- uiscrollview
- Today
- Total
목록Dynamic Member Lookup (2)
김종권의 iOS 앱 개발 알아가기
@dynamicMemberLookup 개념 컴파일 타임에 정의하지 않은 property에 대한 접근을 런타임에 처리하도록 해주는 역할 dynamic member lookup라고 명칭한 이유: 컴파일 타임이 아닌 런타임 기준으로(dynamic) 프로퍼티에 dot으로 접근(member lookup)한다는 의미 런타임에 접근하게 해주는데, 이 때는 dot으로 접근하게끔 하는 역할 @dynamicMemberLookup을 선언하면 subscript(dynamicMember key: String) -> String 필수 구현이 필요 ex) Person이라는 구조체에 @dynamicMemberLookup을 사용 의미: Person이라는 프로퍼티에 접근할 때, 이 인스턴스를 사용하는 쪽에서 런타임에 생성되는 프로퍼티에..
* KeyPath부터 구체적인 dynamic member lookup 개념은 이글 참고 dynamic member lookup @dynamicMemberLookup 키워드를 class, structure, enum, protocol에 적용하여 subscript(dynamicMember:)를 필수로 구현하게하여 런타임시점에 이름으로 dot ‘.’키워드로 접근 가능하도록 하는 방법 dot ‘.’ 키워드 사용하여 이름으로 접근 가능 주의: extension에는 @dynamicMemberLookup 적용 불가 ex) dyanmicMemberLookup을 사용하지 않고 subscript 구현 struct Person1 { var info: [String: String] // name: gender subscrip..