Upgrade to PRO for Only $50/Year—Limited-Time Offer! 🔥
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.6k
リモートワークでBitriseを導入したときにハマりにハマった話
tamappe
0
310
SwiftUIとFlutterを比較する
tamappe
1
1.4k
そのAlertController 回転ロックできないってよ
tamappe
1
730
レアジョブアプリでのアクセス負荷で生じたAPI遅延問題を アプリエンジニア視点で対策を考えてみる
tamappe
0
580
Fat Storyboardをリファクタリングしてみた
tamappe
0
350
Other Decks in Technology
See All in Technology
Karate+Database RiderによるAPI自動テスト導入工数をCline+GitLab MCPを使って2割削減を目指す! / 20251206 Kazuki Takahashi
shift_evolve
PRO
1
750
AWSを使う上で最低限知っておきたいセキュリティ研修を社内で実施した話 ~みんなでやるセキュリティ~
maimyyym
2
800
[JAWS-UG 横浜支部 #91]DevOps Agent vs CloudWatch Investigations -比較と実践-
sh_fk2
2
260
AWS CLIの新しい認証情報設定方法aws loginコマンドの実態
wkm2
6
740
新 Security HubがついにGA!仕組みや料金を深堀り #AWSreInvent #regrowth / AWS Security Hub Advanced GA
masahirokawahara
1
2k
EM歴1年10ヶ月のぼくがぶち当たった苦悩とこれからへ向けて
maaaato
0
280
MLflowダイエット大作戦
lycorptech_jp
PRO
1
120
文字列の並び順 / Unicode Collation
tmtms
3
580
多様なデジタルアイデンティティを攻撃からどうやって守るのか / 20251212
ayokura
0
450
「Managed Instances」と「durable functions」で広がるAWS Lambdaのユースケース
lamaglama39
0
320
Challenging Hardware Contests with Zephyr and Lessons Learned
iotengineer22
0
210
エンジニアとPMのドメイン知識の溝をなくす、 AIネイティブな開発プロセス
applism118
4
1.3k
Featured
See All Featured
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
7.9k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.3k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
1.8k
Learning to Love Humans: Emotional Interface Design
aarron
274
41k
GraphQLの誤解/rethinking-graphql
sonatard
73
11k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3k
Automating Front-end Workflow
addyosmani
1371
200k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Side Projects
sachag
455
43k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
Balancing Empowerment & Direction
lara
5
800
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" }