SlideShare a Scribd company logo
1 of 36
Download to read offline
概要 Powered by Rabbit 2.1.3
概要
須藤功平
株式会社クリアコード
実践リーダブルコード
2015-06-24
概要 Powered by Rabbit 2.1.3
今日の流れ - 午前
10:00- アイスブレーク✓
10:15- 概要と進め方の説明✓
10:45- 実装✓
12:30- ランチ✓
概要 Powered by Rabbit 2.1.3
今日の流れ - 昼下がり
13:30- 読み方のデモ✓
13:45- チェンジして実装✓
15:30- グループふりかえり✓
概要 Powered by Rabbit 2.1.3
今日の流れ - 夕方
16:00- まとめ
次のステップを説明✓
✓
16:30- 感想発表・質疑応答✓
17:00- 有志で懇親会✓
概要 Powered by Rabbit 2.1.3
チューター紹介
参加者のサポート係✓
現役エンジニア✓
行動指針
参加者が目的を見失うのを防ぐ✓
新しい視点を与える✓
✓
概要 Powered by Rabbit 2.1.3
講師紹介
須藤功平(すとう こうへい)
クリアコード代表取締役✓
リーダブルコード(本)の
「解説」の著者
✓
進行と全体を気にかける係✓
概要 Powered by Rabbit 2.1.3
講座の目的
自分の開発チームに
↑注意:個々人の話ではない✓
✓
リーダブルなコードが
当たり前な文化の作り方を
✓
持ち帰る✓
→ 「解説」に書いていることの実践方法を学ぶ
概要 Powered by Rabbit 2.1.3
目的でないこと
実践前の不安のケア
やらない理由の増幅は抑えられない✓
↑のときに外からの声は届かない✓
✓
例:上司の説得方法の伝授
時間が残ったら参加者同士で
情報交換する場を用意
✓
↑を活用するのは可✓
✓
概要 Powered by Rabbit 2.1.3
サポート
今日の資料はすべて再利用可能
チーム内で同じ講座を再現できる✓
✓
無料のフォローアップ面談
チームで実践→悩み
↑の相談に乗る
✓
受講後3ヶ月以内に1回✓
✓
概要 Powered by Rabbit 2.1.3
そもそもの話
リーダブルコードはなぜ必要か✓
↓を目指すために
チームでの共有は必須
リーダブルなコードが
当たり前な文化
概要 Powered by Rabbit 2.1.3
必要なケース
チーム開発
概要 Powered by Rabbit 2.1.3
チーム開発
1人しか触れないコード→危険
いなくなったら変更できない✓
変更できてもコストが大きい✓
✓
チームで触れるには?✓
↓
既存コードの理解が必要
概要 Powered by Rabbit 2.1.3
既存コードの理解のため
リーダブル
コード
概要 Powered by Rabbit 2.1.3
既存コードの理解しやすさ
コードの変更コストに影響
コスト↑→修正・機能追加の時間↑
(理解しないと変更できない)
✓
コスト↑→リグレッションバグ↑
(理解しないまま変更すると問題発生)
✓
✓
↓
理解しやすさ→開発速度に影響
概要 Powered by Rabbit 2.1.3
時間が経つほど影響大
時間
開発
速度
リーダブルじゃない場合
リーダブルな場合
開発速度が落ちにくい
開発速度が落ちやすい
概要 Powered by Rabbit 2.1.3
リーダブルコードの必要性
チームの開発速度の維持のため
継続的に改良・修正したい✓
それも現実的なコストで✓
✓
概要 Powered by Rabbit 2.1.3
必要性の実現方法
コードを読む
文化を作る
概要 Powered by Rabbit 2.1.3
読む?書くじゃないの?
リーダブルコードを書くには
コードを読まないといけない
なぜ?✓
✓
リーダブルコードは
チーム毎に違うから
概要 Powered by Rabbit 2.1.3
リーダブルコード
「読む人」が
読みやすいなら
リーダブル
概要 Powered by Rabbit 2.1.3
読む人
多くの場合、いない
チームのコードを読んでいますか?✓
✓
読む人(チームメンバー)毎に
リーダブルの基準は違う
背景が違うので当たり前
(背景:使ってきた言語・今の知識)
✓
✓
概要 Powered by Rabbit 2.1.3
チームでのリーダブル
1つずつ見つけていくしかない
各メンバーの読んだ感覚を
チームで共有
✓
既存の基準をベースにするのはアリ
(基準:本の内容やコーディングスタイルなど)
✓
✓
チームでのリーダブルコードは
育てていくもの
概要 Powered by Rabbit 2.1.3
リーダブルの基準の育て方
コードを読む文化を作る
(最初の難関)
✓
チームのコードの中から
リーダブルなコードを見つける
✓
リーダブルなコードを
チームで共有
✓
↑の繰り返しで基準を増やす✓
概要 Powered by Rabbit 2.1.3
コードを読む文化を作る
まず自分が読み始める
仲間がいると心強い✓
✓
リーダブルなコードを探す
読みにくいコードは今は置いておく
(チームにコードを読む文化ができてから!)
✓
見つけたリーダブルなコードは…✓
✓
概要 Powered by Rabbit 2.1.3
リーダブルなコードは…
他のメンバーに教える
(例:話しかける。チャットに書く。Wikiにまとめる。)
「○○さんの△△という書き方、
リーダブルでしたよー」
✓
✓
↓
読みやすさの基準を共有
コードが読まれているという自覚
概要 Powered by Rabbit 2.1.3
読むことを「当たり前」に
「あいつはコードを読むやつ」
という認識を広める
✓
自分だけからチームへ✓
…続きはセミナーの最後に
概要 Powered by Rabbit 2.1.3
ワークショップ内容
改良するために
他の人のコードを読む
「まず自分が読み始める」✓
「リーダブルコードを探す」
(読みにくいコードは今は置いておく)
✓
「リーダブルの基準を共有」
(チームでのリーダブルコードができる)
✓
概要 Powered by Rabbit 2.1.3
注意:やらないこと
リーダブルコードを書くための
テクニックをたくさん伝授
概要 Powered by Rabbit 2.1.3
テクニック伝授は範囲外
順番が違う✓
まず読む文化を作ること
今日は↑がメイン✓
✓
テクニックはその後
読む文化ができていれば
効率的に広められる
✓
よい書き方でコードを書けば
みんながコードから学んでくれる!
✓
✓
概要 Powered by Rabbit 2.1.3
やること
読む文化作りの
体験
概要 Powered by Rabbit 2.1.3
読む文化作り
まず自分が読み始める✓
リーダブルコードを探す✓
他のメンバーに教える✓
概要 Powered by Rabbit 2.1.3
読む文化作りの体験
10:45- 課題を実装
リーダブルコードを書く✓
✓
13:30- 実装チェンジ→開発継続
「まず自分が読み始める」✓
「リーダブルコードを探す」✓
✓
15:30- グループ発表
「他のメンバーに教える」✓
✓
概要 Powered by Rabbit 2.1.3
おさらい
講座の目的✓
リーダブルコードの必要性✓
講座でやること✓
概要 Powered by Rabbit 2.1.3
講座の目的
自分の開発チームに
↑注意:個々人の話ではない✓
✓
リーダブルなコードが
当たり前な文化の作り方を
✓
持ち帰る✓
概要 Powered by Rabbit 2.1.3
リーダブルコードの必要性
チームの開発速度の維持のため
継続的に改良・修正したい✓
それも現実的なコストで✓
✓
概要 Powered by Rabbit 2.1.3
変更コストと開発速度
時間
開発
速度
リーダブルじゃない場合
リーダブルな場合
開発速度が落ちにくい
開発速度が落ちやすい
概要 Powered by Rabbit 2.1.3
講座でやること
コードを読む文化作りの体験
まず自分が読み始める✓
リーダブルコードを探す✓
他のメンバーに教える✓
✓

More Related Content

Viewers also liked

SEゼミ2014 - コードチェンジ
SEゼミ2014 - コードチェンジSEゼミ2014 - コードチェンジ
SEゼミ2014 - コードチェンジKouhei Sutou
 
SEゼミ2015 - OSS Hack Weekend - 2日目の概要
SEゼミ2015 - OSS Hack Weekend - 2日目の概要SEゼミ2015 - OSS Hack Weekend - 2日目の概要
SEゼミ2015 - OSS Hack Weekend - 2日目の概要Kouhei Sutou
 
Groongaドキュメント読書会1の進め方
Groongaドキュメント読書会1の進め方Groongaドキュメント読書会1の進め方
Groongaドキュメント読書会1の進め方Kouhei Sutou
 
Groongaドキュメント読書会4の進め方
Groongaドキュメント読書会4の進め方Groongaドキュメント読書会4の進め方
Groongaドキュメント読書会4の進め方Kouhei Sutou
 
リーダブルコードワークショップ(パイオニア向け)の概要
リーダブルコードワークショップ(パイオニア向け)の概要リーダブルコードワークショップ(パイオニア向け)の概要
リーダブルコードワークショップ(パイオニア向け)の概要Kouhei Sutou
 
Hatoholのログ蓄積・検索機能 2014/12版
Hatoholのログ蓄積・検索機能 2014/12版Hatoholのログ蓄積・検索機能 2014/12版
Hatoholのログ蓄積・検索機能 2014/12版Kouhei Sutou
 
Groongaドキュメント読書会3の進め方
Groongaドキュメント読書会3の進め方Groongaドキュメント読書会3の進め方
Groongaドキュメント読書会3の進め方Kouhei Sutou
 
アプリケーションへのRubyインタープリターの組み込み
アプリケーションへのRubyインタープリターの組み込みアプリケーションへのRubyインタープリターの組み込み
アプリケーションへのRubyインタープリターの組み込みKouhei Sutou
 
Rabbit - 時間内に終われるプレゼンツール
Rabbit - 時間内に終われるプレゼンツールRabbit - 時間内に終われるプレゼンツール
Rabbit - 時間内に終われるプレゼンツールKouhei Sutou
 

Viewers also liked (11)

SEゼミ2014 - コードチェンジ
SEゼミ2014 - コードチェンジSEゼミ2014 - コードチェンジ
SEゼミ2014 - コードチェンジ
 
SEゼミ2015 - OSS Hack Weekend - 2日目の概要
SEゼミ2015 - OSS Hack Weekend - 2日目の概要SEゼミ2015 - OSS Hack Weekend - 2日目の概要
SEゼミ2015 - OSS Hack Weekend - 2日目の概要
 
Groongaドキュメント読書会1の進め方
Groongaドキュメント読書会1の進め方Groongaドキュメント読書会1の進め方
Groongaドキュメント読書会1の進め方
 
Groongaドキュメント読書会4の進め方
Groongaドキュメント読書会4の進め方Groongaドキュメント読書会4の進め方
Groongaドキュメント読書会4の進め方
 
リーダブルコードワークショップ(パイオニア向け)の概要
リーダブルコードワークショップ(パイオニア向け)の概要リーダブルコードワークショップ(パイオニア向け)の概要
リーダブルコードワークショップ(パイオニア向け)の概要
 
Hatoholのログ蓄積・検索機能 2014/12版
Hatoholのログ蓄積・検索機能 2014/12版Hatoholのログ蓄積・検索機能 2014/12版
Hatoholのログ蓄積・検索機能 2014/12版
 
Groongaドキュメント読書会3の進め方
Groongaドキュメント読書会3の進め方Groongaドキュメント読書会3の進め方
Groongaドキュメント読書会3の進め方
 
Groonga族2014
Groonga族2014Groonga族2014
Groonga族2014
 
アプリケーションへのRubyインタープリターの組み込み
アプリケーションへのRubyインタープリターの組み込みアプリケーションへのRubyインタープリターの組み込み
アプリケーションへのRubyインタープリターの組み込み
 
Groonga族2013
Groonga族2013Groonga族2013
Groonga族2013
 
Rabbit - 時間内に終われるプレゼンツール
Rabbit - 時間内に終われるプレゼンツールRabbit - 時間内に終われるプレゼンツール
Rabbit - 時間内に終われるプレゼンツール
 

More from Kouhei Sutou

RubyKaigi 2022 - Fast data processing with Ruby and Apache Arrow
RubyKaigi 2022 - Fast data processing with Ruby and Apache ArrowRubyKaigi 2022 - Fast data processing with Ruby and Apache Arrow
RubyKaigi 2022 - Fast data processing with Ruby and Apache ArrowKouhei Sutou
 
Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021
Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021
Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021Kouhei Sutou
 
RubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache Arrow
RubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache ArrowRubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache Arrow
RubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache ArrowKouhei Sutou
 
Rubyと仕事と自由なソフトウェア
Rubyと仕事と自由なソフトウェアRubyと仕事と自由なソフトウェア
Rubyと仕事と自由なソフトウェアKouhei Sutou
 
Apache Arrowフォーマットはなぜ速いのか
Apache Arrowフォーマットはなぜ速いのかApache Arrowフォーマットはなぜ速いのか
Apache Arrowフォーマットはなぜ速いのかKouhei Sutou
 
Apache Arrow 1.0 - A cross-language development platform for in-memory data
Apache Arrow 1.0 - A cross-language development platform for in-memory dataApache Arrow 1.0 - A cross-language development platform for in-memory data
Apache Arrow 1.0 - A cross-language development platform for in-memory dataKouhei Sutou
 
Redmine検索の未来像
Redmine検索の未来像Redmine検索の未来像
Redmine検索の未来像Kouhei Sutou
 
Apache Arrow - A cross-language development platform for in-memory data
Apache Arrow - A cross-language development platform for in-memory dataApache Arrow - A cross-language development platform for in-memory data
Apache Arrow - A cross-language development platform for in-memory dataKouhei Sutou
 
Better CSV processing with Ruby 2.6
Better CSV processing with Ruby 2.6Better CSV processing with Ruby 2.6
Better CSV processing with Ruby 2.6Kouhei Sutou
 
Apache Arrow - データ処理ツールの次世代プラットフォーム
Apache Arrow - データ処理ツールの次世代プラットフォームApache Arrow - データ処理ツールの次世代プラットフォーム
Apache Arrow - データ処理ツールの次世代プラットフォームKouhei Sutou
 
MySQL・PostgreSQLだけで作る高速あいまい全文検索システム
MySQL・PostgreSQLだけで作る高速あいまい全文検索システムMySQL・PostgreSQLだけで作る高速あいまい全文検索システム
MySQL・PostgreSQLだけで作る高速あいまい全文検索システムKouhei Sutou
 
MySQL 8.0でMroonga
MySQL 8.0でMroongaMySQL 8.0でMroonga
MySQL 8.0でMroongaKouhei Sutou
 
Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!
Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!
Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!Kouhei Sutou
 
MariaDBとMroongaで作る全言語対応超高速全文検索システム
MariaDBとMroongaで作る全言語対応超高速全文検索システムMariaDBとMroongaで作る全言語対応超高速全文検索システム
MariaDBとMroongaで作る全言語対応超高速全文検索システムKouhei Sutou
 
PGroonga 2 – Make PostgreSQL rich full text search system backend!
PGroonga 2 – Make PostgreSQL rich full text search system backend!PGroonga 2 – Make PostgreSQL rich full text search system backend!
PGroonga 2 – Make PostgreSQL rich full text search system backend!Kouhei Sutou
 

More from Kouhei Sutou (20)

RubyKaigi 2022 - Fast data processing with Ruby and Apache Arrow
RubyKaigi 2022 - Fast data processing with Ruby and Apache ArrowRubyKaigi 2022 - Fast data processing with Ruby and Apache Arrow
RubyKaigi 2022 - Fast data processing with Ruby and Apache Arrow
 
Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021
Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021
Apache Arrow Flight – ビッグデータ用高速データ転送フレームワーク #dbts2021
 
RubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache Arrow
RubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache ArrowRubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache Arrow
RubyKaigi Takeout 2021 - Red Arrow - Ruby and Apache Arrow
 
Rubyと仕事と自由なソフトウェア
Rubyと仕事と自由なソフトウェアRubyと仕事と自由なソフトウェア
Rubyと仕事と自由なソフトウェア
 
Apache Arrowフォーマットはなぜ速いのか
Apache Arrowフォーマットはなぜ速いのかApache Arrowフォーマットはなぜ速いのか
Apache Arrowフォーマットはなぜ速いのか
 
Apache Arrow 1.0 - A cross-language development platform for in-memory data
Apache Arrow 1.0 - A cross-language development platform for in-memory dataApache Arrow 1.0 - A cross-language development platform for in-memory data
Apache Arrow 1.0 - A cross-language development platform for in-memory data
 
Apache Arrow 2019
Apache Arrow 2019Apache Arrow 2019
Apache Arrow 2019
 
Redmine検索の未来像
Redmine検索の未来像Redmine検索の未来像
Redmine検索の未来像
 
Apache Arrow - A cross-language development platform for in-memory data
Apache Arrow - A cross-language development platform for in-memory dataApache Arrow - A cross-language development platform for in-memory data
Apache Arrow - A cross-language development platform for in-memory data
 
Better CSV processing with Ruby 2.6
Better CSV processing with Ruby 2.6Better CSV processing with Ruby 2.6
Better CSV processing with Ruby 2.6
 
Apache Arrow
Apache ArrowApache Arrow
Apache Arrow
 
Apache Arrow - データ処理ツールの次世代プラットフォーム
Apache Arrow - データ処理ツールの次世代プラットフォームApache Arrow - データ処理ツールの次世代プラットフォーム
Apache Arrow - データ処理ツールの次世代プラットフォーム
 
Apache Arrow
Apache ArrowApache Arrow
Apache Arrow
 
MySQL・PostgreSQLだけで作る高速あいまい全文検索システム
MySQL・PostgreSQLだけで作る高速あいまい全文検索システムMySQL・PostgreSQLだけで作る高速あいまい全文検索システム
MySQL・PostgreSQLだけで作る高速あいまい全文検索システム
 
MySQL 8.0でMroonga
MySQL 8.0でMroongaMySQL 8.0でMroonga
MySQL 8.0でMroonga
 
My way with Ruby
My way with RubyMy way with Ruby
My way with Ruby
 
Red Data Tools
Red Data ToolsRed Data Tools
Red Data Tools
 
Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!
Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!
Mroongaの高速全文検索機能でWordPress内のコンテンツを有効活用!
 
MariaDBとMroongaで作る全言語対応超高速全文検索システム
MariaDBとMroongaで作る全言語対応超高速全文検索システムMariaDBとMroongaで作る全言語対応超高速全文検索システム
MariaDBとMroongaで作る全言語対応超高速全文検索システム
 
PGroonga 2 – Make PostgreSQL rich full text search system backend!
PGroonga 2 – Make PostgreSQL rich full text search system backend!PGroonga 2 – Make PostgreSQL rich full text search system backend!
PGroonga 2 – Make PostgreSQL rich full text search system backend!
 

実践リーダブルコードの概要

  • 1. 概要 Powered by Rabbit 2.1.3 概要 須藤功平 株式会社クリアコード 実践リーダブルコード 2015-06-24
  • 2. 概要 Powered by Rabbit 2.1.3 今日の流れ - 午前 10:00- アイスブレーク✓ 10:15- 概要と進め方の説明✓ 10:45- 実装✓ 12:30- ランチ✓
  • 3. 概要 Powered by Rabbit 2.1.3 今日の流れ - 昼下がり 13:30- 読み方のデモ✓ 13:45- チェンジして実装✓ 15:30- グループふりかえり✓
  • 4. 概要 Powered by Rabbit 2.1.3 今日の流れ - 夕方 16:00- まとめ 次のステップを説明✓ ✓ 16:30- 感想発表・質疑応答✓ 17:00- 有志で懇親会✓
  • 5. 概要 Powered by Rabbit 2.1.3 チューター紹介 参加者のサポート係✓ 現役エンジニア✓ 行動指針 参加者が目的を見失うのを防ぐ✓ 新しい視点を与える✓ ✓
  • 6. 概要 Powered by Rabbit 2.1.3 講師紹介 須藤功平(すとう こうへい) クリアコード代表取締役✓ リーダブルコード(本)の 「解説」の著者 ✓ 進行と全体を気にかける係✓
  • 7. 概要 Powered by Rabbit 2.1.3 講座の目的 自分の開発チームに ↑注意:個々人の話ではない✓ ✓ リーダブルなコードが 当たり前な文化の作り方を ✓ 持ち帰る✓ → 「解説」に書いていることの実践方法を学ぶ
  • 8. 概要 Powered by Rabbit 2.1.3 目的でないこと 実践前の不安のケア やらない理由の増幅は抑えられない✓ ↑のときに外からの声は届かない✓ ✓ 例:上司の説得方法の伝授 時間が残ったら参加者同士で 情報交換する場を用意 ✓ ↑を活用するのは可✓ ✓
  • 9. 概要 Powered by Rabbit 2.1.3 サポート 今日の資料はすべて再利用可能 チーム内で同じ講座を再現できる✓ ✓ 無料のフォローアップ面談 チームで実践→悩み ↑の相談に乗る ✓ 受講後3ヶ月以内に1回✓ ✓
  • 10. 概要 Powered by Rabbit 2.1.3 そもそもの話 リーダブルコードはなぜ必要か✓ ↓を目指すために チームでの共有は必須 リーダブルなコードが 当たり前な文化
  • 11. 概要 Powered by Rabbit 2.1.3 必要なケース チーム開発
  • 12. 概要 Powered by Rabbit 2.1.3 チーム開発 1人しか触れないコード→危険 いなくなったら変更できない✓ 変更できてもコストが大きい✓ ✓ チームで触れるには?✓ ↓ 既存コードの理解が必要
  • 13. 概要 Powered by Rabbit 2.1.3 既存コードの理解のため リーダブル コード
  • 14. 概要 Powered by Rabbit 2.1.3 既存コードの理解しやすさ コードの変更コストに影響 コスト↑→修正・機能追加の時間↑ (理解しないと変更できない) ✓ コスト↑→リグレッションバグ↑ (理解しないまま変更すると問題発生) ✓ ✓ ↓ 理解しやすさ→開発速度に影響
  • 15. 概要 Powered by Rabbit 2.1.3 時間が経つほど影響大 時間 開発 速度 リーダブルじゃない場合 リーダブルな場合 開発速度が落ちにくい 開発速度が落ちやすい
  • 16. 概要 Powered by Rabbit 2.1.3 リーダブルコードの必要性 チームの開発速度の維持のため 継続的に改良・修正したい✓ それも現実的なコストで✓ ✓
  • 17. 概要 Powered by Rabbit 2.1.3 必要性の実現方法 コードを読む 文化を作る
  • 18. 概要 Powered by Rabbit 2.1.3 読む?書くじゃないの? リーダブルコードを書くには コードを読まないといけない なぜ?✓ ✓ リーダブルコードは チーム毎に違うから
  • 19. 概要 Powered by Rabbit 2.1.3 リーダブルコード 「読む人」が 読みやすいなら リーダブル
  • 20. 概要 Powered by Rabbit 2.1.3 読む人 多くの場合、いない チームのコードを読んでいますか?✓ ✓ 読む人(チームメンバー)毎に リーダブルの基準は違う 背景が違うので当たり前 (背景:使ってきた言語・今の知識) ✓ ✓
  • 21. 概要 Powered by Rabbit 2.1.3 チームでのリーダブル 1つずつ見つけていくしかない 各メンバーの読んだ感覚を チームで共有 ✓ 既存の基準をベースにするのはアリ (基準:本の内容やコーディングスタイルなど) ✓ ✓ チームでのリーダブルコードは 育てていくもの
  • 22. 概要 Powered by Rabbit 2.1.3 リーダブルの基準の育て方 コードを読む文化を作る (最初の難関) ✓ チームのコードの中から リーダブルなコードを見つける ✓ リーダブルなコードを チームで共有 ✓ ↑の繰り返しで基準を増やす✓
  • 23. 概要 Powered by Rabbit 2.1.3 コードを読む文化を作る まず自分が読み始める 仲間がいると心強い✓ ✓ リーダブルなコードを探す 読みにくいコードは今は置いておく (チームにコードを読む文化ができてから!) ✓ 見つけたリーダブルなコードは…✓ ✓
  • 24. 概要 Powered by Rabbit 2.1.3 リーダブルなコードは… 他のメンバーに教える (例:話しかける。チャットに書く。Wikiにまとめる。) 「○○さんの△△という書き方、 リーダブルでしたよー」 ✓ ✓ ↓ 読みやすさの基準を共有 コードが読まれているという自覚
  • 25. 概要 Powered by Rabbit 2.1.3 読むことを「当たり前」に 「あいつはコードを読むやつ」 という認識を広める ✓ 自分だけからチームへ✓ …続きはセミナーの最後に
  • 26. 概要 Powered by Rabbit 2.1.3 ワークショップ内容 改良するために 他の人のコードを読む 「まず自分が読み始める」✓ 「リーダブルコードを探す」 (読みにくいコードは今は置いておく) ✓ 「リーダブルの基準を共有」 (チームでのリーダブルコードができる) ✓
  • 27. 概要 Powered by Rabbit 2.1.3 注意:やらないこと リーダブルコードを書くための テクニックをたくさん伝授
  • 28. 概要 Powered by Rabbit 2.1.3 テクニック伝授は範囲外 順番が違う✓ まず読む文化を作ること 今日は↑がメイン✓ ✓ テクニックはその後 読む文化ができていれば 効率的に広められる ✓ よい書き方でコードを書けば みんながコードから学んでくれる! ✓ ✓
  • 29. 概要 Powered by Rabbit 2.1.3 やること 読む文化作りの 体験
  • 30. 概要 Powered by Rabbit 2.1.3 読む文化作り まず自分が読み始める✓ リーダブルコードを探す✓ 他のメンバーに教える✓
  • 31. 概要 Powered by Rabbit 2.1.3 読む文化作りの体験 10:45- 課題を実装 リーダブルコードを書く✓ ✓ 13:30- 実装チェンジ→開発継続 「まず自分が読み始める」✓ 「リーダブルコードを探す」✓ ✓ 15:30- グループ発表 「他のメンバーに教える」✓ ✓
  • 32. 概要 Powered by Rabbit 2.1.3 おさらい 講座の目的✓ リーダブルコードの必要性✓ 講座でやること✓
  • 33. 概要 Powered by Rabbit 2.1.3 講座の目的 自分の開発チームに ↑注意:個々人の話ではない✓ ✓ リーダブルなコードが 当たり前な文化の作り方を ✓ 持ち帰る✓
  • 34. 概要 Powered by Rabbit 2.1.3 リーダブルコードの必要性 チームの開発速度の維持のため 継続的に改良・修正したい✓ それも現実的なコストで✓ ✓
  • 35. 概要 Powered by Rabbit 2.1.3 変更コストと開発速度 時間 開発 速度 リーダブルじゃない場合 リーダブルな場合 開発速度が落ちにくい 開発速度が落ちやすい
  • 36. 概要 Powered by Rabbit 2.1.3 講座でやること コードを読む文化作りの体験 まず自分が読み始める✓ リーダブルコードを探す✓ 他のメンバーに教える✓ ✓