Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
良い設計のプログラムを作 るには アジャイル時代に必要とされる設計
Slide 2
Slide 2 text
アジャイルの時代
Slide 3
Slide 3 text
アジャイル時代に必要とされる設計 目指すところはそんなに変 わらないですけどね。
Slide 4
Slide 4 text
アジャイル時代に必要とされる設計 ただ途中経過は結構違っ ているかもしれない。
Slide 5
Slide 5 text
アジャイルでプログラムはどう変わったか 少々の手戻りはどんとこい 変更はいつでも修正できる
Slide 6
Slide 6 text
アジャイルでプログラムはどう変わったか そもそも理想的な設計は 一つに決まらない
Slide 7
Slide 7 text
アジャイルでプログラムはどう変わったか 機能が変更されれば最適な設計も変わる
Slide 8
Slide 8 text
アジャイルでプログラムはどう変わったか テスト駆動開発では、内部 設計はリファクタリング時 に行う。 常にゴールが変 わる中で、常に 最適を保つ。
Slide 9
Slide 9 text
設計方針
Slide 10
Slide 10 text
DRY DRY Don't repeat yourself 絶対に二度書かない
Slide 11
Slide 11 text
DRY 本当に同じこ とは絶対に二 度書くな! 別に2回書く のが面倒だか らじゃないか ら。 影響範囲調べ る必要がない コートにする。
Slide 12
Slide 12 text
DRY 厳密に絶対かと言えばさすがにそうじゃないけど。 たまたま同じ書き方になっているだけで違う意味の場合。 どう工夫してもその言語では絶対共通化できない場合。 無理やり共通化したほうが明らかに読みにくくなっている場合。
Slide 13
Slide 13 text
YAGNI YAGNI You ain't gonna need it いずれ必要にならない
Slide 14
Slide 14 text
YAGNI 必要にならなくても存在する以上は必ずコストがかかる。 必要になった時に当初想像していた仕様で問題ないことは少ない。 後で追加がよほど面倒な時はさすがに話が別だが。
Slide 15
Slide 15 text
オブジェクト指向設計 昔からの「正しい設 計」に近づけていく
Slide 16
Slide 16 text
抽象化 人間に対してプログラムを書く char*ではなく string型を使う “YYYYMMDD”では なくDate型を使う
Slide 17
Slide 17 text
識別子には適切な名前を付ける 解読しやすい 読めば分かるので解読する必要もない numberOfPeopleOnTheUSOlympicTeam maximumNumberOfPointsInModernOlympics checkTotal currentDate linesPerPage
Slide 18
Slide 18 text
識別子には適切な名前を付ける 辞書や類語辞典を使う 語順は正しい文法で 現在分詞や過去分詞をつかう 手を抜くな!!
Slide 19
Slide 19 text
推敲 門を推すというか敲くというか一晩考える。 もちろん文法は全部使えるのが当然です。 日本語の文章を推敲するのと全く同じ作業。