海外事業向けのiOSアプリケーション開発を担当している西山(@yuseinishiyama)です。より海外事業に注力するため、今年度から、海外事業の拠点であるイギリス、Bristolのオフィスに出向しています。クックパッドは現在、15言語、58カ国以上を対象にサービスを展開しています。
先日、ヴァンサンが国内向けのアプリケーションのSwift 3化に関する記事を投稿しました。同じく、海外向けのアプリケーションも、昨年12月にSwift 3化した最初のバージョンをリリースしました。以前、Swift移行の記事で説明したとおり、このプロジェクトはほぼSwiftによって実装されているため、Swift 3化によってほぼ全てのコードが影響を受けました。幸いにも、大きなトラブルは起きませんでした。
この度、こうした業務での経験を活かして、『Swift実践入門』という書籍を技術評論社のWEB+DB PRESS plusシリーズから2月7日に発売することになりましたので、この場を借りて宣伝させていただきます。APIKitなどで著名な@_ishkawaさんとの共著となります。
Swift実践入門 ── 直感的な文法と安全性を兼ね備えた言語 (WEB+DB PRESS plus)
- 作者:石川洋資,西山勇世
- 出版社/メーカー:技術評論社
- 発売日: 2017/02/07
- メディア:単行本(ソフトカバー)
- この商品を含むブログを見る
また、刊行記念のイベントも開催することになりましたので、興味のある方はぜひご参加ください。
執筆の動機 〜Swiftのwhyとwhenの解消〜
SwiftがAppleから発表されたのは2014年です。安全かつ簡潔な文法という触れ込みが印象的でした。iOS開発者としては当然居ても立ってもいられず、発表後すぐ、beta版の公式ドキュメントの全てに目を通しました。そこで強く感じたことは、「簡潔ではあるが簡単ではない」ということです。Objective-Cのユニークな記法と比較すると、フレンドリーな見た目にはなりましたが、その豊富な言語仕様を適切に使いこなすのは容易ではないと思いました。
Appleの公式ドキュメントをはじめとして、どんな(what)言語仕様があり、それらをどのように(how)使うかに関しては早い段階から豊富な情報源がありましたが、それらがなぜ(why)存在し、いつ(when)使うべきかについてまとまった情報があるとは言えない状況でした。『Swift実践入門』はこうした状況を解消することを主眼としています。
Swiftの難しさ 〜Swiftらしいコードを書くために必要な知識〜
単にSwiftでコードを書くことと、Swiftらしいコードを書くことは別のことです。ここで言うSwiftらしさとは、Swiftがその言語仕様を持って実現したい世界に倣ったコードのことです。Swiftは豊富な言語仕様を持っていますが、それは同時に、豊富な選択肢があるということを意味します。全てのケースに当てはめれるような解があるわけではなく、それぞれの仕様の存在意義を明確に把握し、都度適切な判断を下さなければなりません。
初学者がSwiftの言語仕様をある程度理解した後に躓きやすい典型的な箇所として、次のようなものが挙げられます(「使い分け」という言葉が繰り返し登場することから、同じことをするにも複数の方法があることが見て取れるでしょう)。
Optional<Wrapped>
の使い所- 高機能なパターンマッチ
- モジュールのアクセスレベル
- プロトコルと継承の使い分け
- キャプチャリストの使い分け(
weak
、unowned
、何もつけない) - 値型と参照型使い分け
if
とguard
の使い分け- 定数と変数の使い分け
- エラー処理の使い分け(
Optional<Wrapped>
、do
-catch
、Result<T, Error>
)
例えば、「Optional<Wrapped>
の使い所」を説明するために、書籍内では次のようなコードが登場します。どちらにどのようなメリットがあるか適切に説明できるでしょうか。
// 全てのプロパティがOptional<Wrapped>型のケースstructUser { letid:Int? letname:String? letmailAddress:String? init(json:[String : Any]) { id = json["id"] as? Int name = json["name"] as? String mailAddress = json["mailAddress"] as? String } } // Failable Initializerを使うケースstructUser { letid:Intletname:StringletmailAddress:String? init?(json:[String : Any]) { guardletid= json["age"] as? Int, letname= json["name"] as? String else { returnnil } self.id = id self.name = name self.mailAddress = json["email"] as? String } }
『Swift実践入門』は、これらのこと1つ1つ言及し、読者のwhyやwhenを解消します。
おわりに
『Swift実践入門』はその名の通り、単なる入門書や言語仕様の解説にとどまらない、実践的な内容を扱っています。著者2人で450ページ強というなかなかのボリュームですが、これからSwiftをはじめようという方から、よりその知識を深めたいという方にまで、ぜひ手にとっていただきたい一冊です。
一方、『Swift実践入門』は実践的な書籍ではありますが、やはり本当の意味での「実践」からしか得られないこともたくさんあります。例えば、クックパッドでは長期間に渡って大量のユーザーを支えることができるアプリケーションを構築する必要がありますが、そのためにはさらに進んだトピックに取り組まなければいけません。例えば、チームに最適化されたStyle Guideを制定したり、肥大化するビルド時間に対処することがそれにあたります。
クックパッドでは、こうしたAdvancedな課題に対処したいSwiftエンジニアも募集しています。
国内事業: https://recruit.cookpad.com/jobs/career_recruitment/ios-android/