先日dots.さんが主催するAndroidオールスターズという勉強会で、"Android Clean Architectureことはじめ"と題して発表してきました。
資料はこちらになります。
www.slideshare.net
また資料でお見せしたサンプルコードは https://github.com/tomoima525/CleanArchitectureSample になります。プリミティブな形でサンプルをお見せしたかったため、ほぼデファクトスタンダートとなっているRetrofitとButter Knife以外のライブラリは利用せずに書いています。
最低限の実装なので色々荒くなってるし、テストガーとか言ってたくせにテストも書けてないので、後ほどもう少しブラッシュアップしてテストも書きます。気になる方はwatchしていただければと思います。
設計とは(良いコードを書きたいっていう)意志であり、フレームワークなんて関係ねぇ
上記はUncle Bobさんの"Architecture is about Intent, not Frameworks"という言葉の意訳です。発表の最後でも話したのですが、結局のところ、設計はこの言葉につきるかと思います。
自分も、Androidの設計について色々調べ始めたきっかけは、1000行を超えるActivityやMVCと銘打ちながらもAndroid Frameworkが絡んでこんがらがってしまったコードをなんとかしたい、と考えたからでした。
今回は"The Clean Architecture"というUncle Bobが提案した設計思想をベースにした設計をご紹介しました。これ以外にも、MVVMやFacebookのFluxなど、様々な設計手法があります。一体何がいいのか迷ってしまいますが、これらのうちから一つ選んでまるっと採用する必要はなく、良いとこどりして出来る範囲で、コストに見合う形で、自分のサービスに取り込んで行けばよいのではないかな〜と思います。なので、資料でも、どこから手を付ければよいかの指針を書いています。
またチームで開発している場合、メンバーの意志を合わせていくことも重要になります。新しい手法を試す場合はチーム勉強会を開く、レビューで気をつけるなど、全員が同じ方向を向くように頑張らないと、設計が崩壊してしまいます。やっぱり意志が大事なんですね。
個人であれチームであれ、良い設計を通じて最終的には楽しく(ここ大事)迷わずサービスにフォーカスして作れることが一番だと思う次第であります。
Android Clean Architectureに関するリンク集
自分がAndroid Clean Architectureを学ぶにあたって参考にしたリンクをまとめておきます。もうちょっと学んでみたいと思ったら参考にしてください。
MVP
MVP for Android
自分が見つけた中で一番シンプルなMVPの実装です。Daggerなどのライブラリを使わずにシンプルにMVPのアーキテクチャを実装しています。
説明: http://antonioleiva.com/mvp-android/
ソースコード: https://github.com/antoniolg/androidmvpIntroduction to Model View Presenter
こちらもMVPのサンプルです。ただ、自分で作ったライブラリも利用しています。
https://github.com/konmik/konmik.github.io/wiki/Introduction-to-Model-View-Presenter-on-AndroidEffective Android UI
MVPの基本的な内容と、MVVMについても説明しています。
説明: http://www.slideshare.net/PedroVicenteGmezSnch/effective-android-ui-english
ソースコード: https://github.com/pedrovgs/EffectiveAndroidUI/
The Clean Architecture
- The Clean Architecture
Uncle Bobが提案したClean Architectureの説明です。平たく言うと、"ビジネスロジックをUIやフレームワークから開放しよう"といったところでしょうか。個人的には、この設計思想はとても優れたものだと思っています。
http://blog.8thlight.com/uncle-bob/2012/08/13/the-clean-architecture.html
Android Clean Architecture
Architecting Android The Clean Way
恐らくClean Architectureをベースにした一番最初の設計なのではないかと思います。当初はシンプルな実装のようでしたが、今はDagger2, RxJavaを使ったものとなっています。
説明:http://fernandocejas.com/2014/09/03/architecting-android-the-clean-way/
ソースコード:https://github.com/android10/Android-CleanArchitectureClean Android Architecture
MVCモデルをいかに機能分割してThe Clean Architectureに持っていくか、についてまとめた資料です。とてもわかりやすく分割の過程がわかります。
https://speakerdeck.com/richk/clean-android-architectureこれから設計の話をしよう
@kgmyshinさんの資料。なぜ優れた設計をすべきかとAndroid で綺麗な実装をするための指針が大変わかりやすくまとまっている素晴らしい資料です。インフラ層の考え方などとても参考になります。日本語です。
http://www.slideshare.net/shinnosukekugimiya/ss-50705888
最後に:Androidオールスターズについて
その他の方の資料はこちらにまとめがありました。当日の感想ツイートなんかもまとまってます。他の登壇者の方たちの発表はレベル高くてめっちゃ勉強になりましたし、改めてほんと精進しないと、って思いました。 会場を提供いただいたshibuya dots.さんは8月に出来たスペースとのことで、今までの会場にない、家のような落ち着いた雰囲気の場所でした。写真はテンパってて撮り忘れたのですが、Webサイトをみていただくとわかるかと思います。運営の皆様、ありがとうございました!