Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Swift4.2で追加されたDynamic Member Lookupを使ってみよう
Search
tamappe
March 19, 2019
Technology
0
920
Swift4.2で追加されたDynamic Member Lookupを使ってみよう
try! Swift Pre Talks でお話ししました登壇資料です @tamappe
tamappe
March 19, 2019
Tweet
Share
More Decks by tamappe
See All by tamappe
async/awaitの性能をDartとSwiftとの比較で読み解く
tamappe
2
1.7k
商業雑誌に技術記事を寄稿した振り返り
tamappe
3
1.7k
リモートワークでBitriseを導入したときにハマりにハマった話
tamappe
0
310
SwiftUIとFlutterを比較する
tamappe
1
1.4k
そのAlertController 回転ロックできないってよ
tamappe
1
740
レアジョブアプリでのアクセス負荷で生じたAPI遅延問題を アプリエンジニア視点で対策を考えてみる
tamappe
0
590
Fat Storyboardをリファクタリングしてみた
tamappe
0
350
Other Decks in Technology
See All in Technology
ルネサンス開発者を育てる 1on1支援AIエージェント
yusukeshimizu
0
130
AWSに革命を起こすかもしれない新サービス・アップデートについてのお話
yama3133
0
540
技術選定、下から見るか?横から見るか?
masakiokuda
0
170
業務の煩悩を祓うAI活用術108選 / AI 108 Usages
smartbank
9
19k
ECS_EKS以外の選択肢_ROSA入門_.pdf
masakiokuda
1
120
Directions Asia 2025 _ Let’s build my own secretary (AI Agent) Part 1 & 2
ryoheig0405
0
110
スクラムマスターが スクラムチームに入って取り組む5つのこと - スクラムガイドには書いてないけど入った当初から取り組んでおきたい大切なこと -
scrummasudar
0
510
あの夜、私たちは「人間」に戻った。 ── 災害ユートピア、贈与、そしてアジャイルの再構築 / 20260108 Hiromitsu Akiba
shift_evolve
PRO
0
250
LayerX QA Night#1
koyaman2
0
300
20251225_たのしい出張報告&IgniteRecap!
ponponmikankan
0
100
アラフォーおじさん、はじめてre:Inventに行く / A 40-Something Guy’s First re:Invent Adventure
kaminashi
0
210
Oracle Cloud Infrastructure:2025年12月度サービス・アップデート
oracle4engineer
PRO
0
170
Featured
See All Featured
Highjacked: Video Game Concept Design
rkendrick25
PRO
0
260
Ruling the World: When Life Gets Gamed
codingconduct
0
120
For a Future-Friendly Web
brad_frost
180
10k
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
140
Game over? The fight for quality and originality in the time of robots
wayneb77
1
73
AI: The stuff that nobody shows you
jnunemaker
PRO
1
130
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
0
26
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.6k
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
76
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.1k
The Invisible Side of Design
smashingmag
302
51k
Embracing the Ebb and Flow
colly
88
4.9k
Transcript
-FU`TVTF %ZOBNJD.FNCFS-PPLVQ JOUSPEVDFEJO4XJGU !UBNBQQF USZ4XJGU1SF5BMLT
struct Me { let name = “Yosuke Tamaoki” let age
= 31 let company = “Summer" + “Freelance“ let os = "iOS" + "Android" let hobby = "Splatoon2" + “Poker" struct Language { let swift let objective-c let java let kotlin } } "CPVU!UBNBQQF
1PXFSPGEZOBNJDNFNCFSMPPLVQ )PXUP*NQMFNFOU 4BNQMFDPEFT $PODMVTJPO 4VNNBSZPGNZUBML !EZOBNJD.FNCFS-PPLVQ QSPUPDPM\^
// Dictionary let classRoom: [String: Any] = [ "teacher": "Yamada",
“studentNum”: 30 ] // before let teacher = classRoom["teacher"] // "Yamada" let count = classRoom["studentNum"] // 30 let teacher = classRoom.teacher // compile error let count = classRoom.studentNum // compile error // after let teacher = classRoom.teacher // "Yamada" let count = classRoom.studentNum // 30 1PXFSPGEZOBNJDNFNCFSMPPLVQ
"EE!EZOBNJD.FNCFS-PPLVQ CFGPSFUIFDMBTT "EElTVCTDSJQUzEFpOJUJPO "EEMBCFMEZOBNJD.FNCFSUP UIFBSHVNFOUPGTVCTDSJQUEFpOJUJPO )PXUP*NQMFNFOU
4BNQMFDPEF $MBTT 4USVDU 1SPUPDPM &OVN &YQMBJO &YQMBJO TMJEFPOMZ TMJEFPOMZ
$MBTTDBTF @dynamicMemberLookup class User { let firstName: String let lastName:
String let age: Int init(firstName: String, lastName: String, age: Int) { self.firstName = firstName self.lastName = lastName self.age = age } subscript(dynamicMember key: String) -> Any { switch key { case "upperFirstName": return firstName.uppercased() case "upperLastName": return lastName.uppercased() case "adalt": return 30 case "children": return 15 default: return "" } } }
$MBTTDBTF @dynamicMemberLookup class User { let firstName: String let lastName:
String let age: Int init(firstName: String, lastName: String, age: Int) { self.firstName = firstName self.lastName = lastName self.age = age } subscript(dynamicMember key: String) -> Any { switch key { case "upperFirstName": return firstName.uppercased() case "upperLastName": return lastName.uppercased() case "adalt": return 30 case "children": return 15 default: return "" } } }
6TFDBTF let hanakoYamada = User(firstName: "Hanako", lastName: "Yamada", age: 20)
print(hanakoYamada.firstName) // "Hanako" print(hanakoYamada.lastName) // "Yamada" print(hanakoYamada.age) // 20 print(hanakoYamada.upperFirstName) // "HANAKO" print(hanakoYamada.upperLastName) // "YAMADA" print(hanakoYamada.adalt) // 30 print(hanakoYamada.children) // 15 print(hanakoYamada.young) // ""
TUSVDUDBTF @dynamicMemberLookup struct Person { subscript(dynamicMember name: String) -> String
{ return "Hello, \(name)" } }
TUSVDUDBTF @dynamicMemberLookup struct Person { subscript(dynamicMember name: String) -> String
{ return "Hello, \(name)" } }
6TFDBTF let person = Person() print(person.swift) // "Hello, swift” print(person.hanako)
// "Hello, hanako” print(person.taro) // "Hello, taro"
5IBU`T"MM 5IBOLZPV https://blog.tamappe.com
1SPUPDPMDBTF @dynamicMemberLookup protocol SampleProtocol { associatedtype Key associatedtype Value subscript(key:
Key) -> Value? { get } } extension SampleProtocol where Key == String { subscript(dynamicMember member: String) -> Value? { return self[member] } } extension Dictionary: SampleProtocol {} 1SPUPDPMFYUFOTJPO
6TFDBTF let hanakoDic: [String : Any] = [ "firstName": "hanako",
"lastName": "yamada", "age": 20 ] print(hanakoDic.firstName as! String) // “hanako" print(hanakoDic.age as! Int) // 20
&OVNDBTF @dynamicMemberLookup enum JSON { case number(Int) case string(String) case
array([JSON]) case dictionary([String: JSON]) subscript(dynamicMember key: String) -> JSON? { guard case .dictionary(let dict) = self else { return nil } return dict[key] } } extension JSON { var numberValue: Int? { guard case .number(let n) = self else { return nil } return n } var stringValue: String? { guard case .string(let s) = self else { return nil } return s } subscript(index: Int) -> JSON? { guard case .array(let arr) = self, arr.indices.contains(index) else { return nil } return arr[index] } subscript(key: String) -> JSON? { guard case .dictionary(let dict) = self else { return nil } return dict[key] } } +40/
&OVNDBTF @dynamicMemberLookup enum JSON { case number(Int) case string(String) case
array([JSON]) case dictionary([String: JSON]) subscript(dynamicMember key: String) -> JSON? { guard case .dictionary(let dict) = self else { return nil } return dict[key] } } +40/
&OVNDBTF extension JSON { var numberValue: Int? { guard case
.number(let n) = self else { return nil } return n } var stringValue: String? { guard case .string(let s) = self else { return nil } return s } subscript(index: Int) -> JSON? { guard case .array(let arr) = self, arr.indices.contains(index) else { return nil } return arr[index] } subscript(key: String) -> JSON? { guard case .dictionary(let dict) = self else { return nil } return dict[key] } } +40/
6TFDBTF let json = JSON.dictionary([ "firstName": .string("hanako"), "lastName": .string("Yamada"), "age":
.number(20), "language": .array([ .string(“Swift"), .string("Objective-c"), .string("Kotlin"), .string("Java"), ]) ]) if let firstName = json.firstName?.stringValue { print(firstName) // "hanako" }