人生で大事なことは XP白本と参考文献に教わった
-
Upload
takeshi-kakeda -
Category
Software
-
view
1.737 -
download
2
description
Transcript of 人生で大事なことは XP白本と参考文献に教わった
人生で大事なことは XP白本と
参考文献に教わった ~本と本の間の見えない糸を辿り、
XPをより深く知る~
2014/09/05 XP祭り2014 C-6
CultureWorksAgile459
kkdhttp://giantech.jp
懸田 剛Kakeda Takeshi
http://myj.cultureworks.jp
9年14年
–Kent Beck
“5年前、本書の初版が出版された頃には、 途方もなく「エクストリーム」に思えた プラクティスが一般的になっている。
本書に掲載するプラクティスは、今から5年後には保守的な方法になっているのだろう。”
日本語版:http://d.hatena.ne.jp/yach/20140424
XPはAgileの細胞として様々な場所に偏在するに至った
Annotated Bibliography 解説付き参考文献
「さまざまな書籍を読んだことで、私の理解は深くなった。ここでは、XPに関連したアイデアを提供する
いくつかの興味深い書籍を示す。」
8759
参考文献数
哲学
態度
創発プロセス
システム
人
プロジェクトマネジメント
プログラミング
その他
0 5 10 15 20
1st 2nd
Annotated bib change !Hello, !My officemate and I just noticed that /Sex Tips for Girls/ is missing from the annotated bibliography in xp2e. !Can you reveal the motivation behind that, and/or elaborate on other deltas between the two bibliographies? !Thanks,
“セックスチップスforガールズが消えてるんだけど?”
Bil Kleb | 2 Mar 19:39 2006
RE: Annotated bib change !Bil, !I don't remember all of the changes I made to the bibliography. My intention with the second edition was to write a business-like book, since programming is, for most of us, a business. Shock for the sake of shock brought me a certain amount of attention, but it didn't contribute to my fundamental goals. !Sincerely yours, !Kent Beck Three Rivers Institute
“ビジネスライクな本にしたかったからのけちゃった”
Kent Beck | 8 Mar 19:07 2006
哲学
態度創発プロセス
システム
人
プロジェクト マネジメント
プログラミングその他
G.M.ワインバーグ
–Kent Beck
“言うこととやることが矛盾する時、悪い結果が起きる。本書は、どうやって言行一致の人になるか、他人の言行不一致をどう見破るか、それにどう対処するかについてであ
る。”
–Kent Beck
“私が実際に持っている価値は、 私が持っていると世間に思わせたい価値で
はないことに気づいた。 これまでの5年間は、私の実際の価値を、理想の価値に変えるための旅であった。”
なぜ参考文献?
–Kent Beck
“アレクサンダーは設計を次のように考えることから始める。設計とは、相矛盾する制約間の対立を解決するための決断であり、それでもなお残る制約を解決するための決断を導き
出すものですある。”
–Kent Beck
“クリストファー・アレクサンダーの建築と施工に対する考え方の概説。設計者および施工者とその建築物を使う人との関係は、プログラマと顧
客の関係によく似ている。”
–Kent Beck
“新しい特性を生むためのルール体系の一例。このルールがよいかどうかには議論の余地があるが、ルール自体は一読の価値がある。また、とても短いが、作業空間の設計についての素晴らしい
議論が記述されている。”
–Kent Beck
“自分の考えを図で表現する方法。 線形に物事を考える人と 非線形に考える人との
コミュニケーションを促進する”
Astah(旧JUDE)のマインドマップ(2005/4/14~)
Nancy Margulies
World Cafe’s Co-Developer
http://education.jhu.edu/PD/newhorizons/strategies/topics/Graphic%20Tools%20for%20Learning/margulies.htm
http://education.jhu.edu/PD/newhorizons/strategies/topics/Graphic%20Tools%20for%20Learning/margulies.htm
http://education.jhu.edu/PD/newhorizons/strategies/topics/Graphic%20Tools%20for%20Learning/margulies.htm
–Kent Beck
“この本も、比喩(メタファ)と思想についてよく論じている。比喩同士がどのような形であれ融合することで、まったく別の新しい比喩が出来るかについても述べており、これはソフトウェア工学の考え方と良く似ている。土木工学や数学などから来た古い比喩が、時間をかけてソフトウェア工学特
有の比喩になっていくのだ。”
メタファは 単なるレトリックではなく 思考と深く結びついている
時は金なり
時間を浪費する。 時間を節約する。 時間をムダにする。
時間を貯める(とは言わない)
http://www.slideshare.net/kkd/metaphors-we-develop-a-software-by-7661294
–G.M.ワインバーグ
“バグという言葉を使っている組織は, 欠陥という言語を使っている組織とは 異なった方法でソフトウェアを開発し,
保守している。”
サピア=ウォーフ仮説
“「人間の経験や思考の様式はその言語習慣によって実は規定されているのであり、従って異
なる言語を用いている人たちの間では経験や思考の様式も違うのではないか」という考え方。”
http://hirataka.sfc.keio.ac.jp/rindoku2.htm
TDD BDDと
–A NEW LOOK AT TEST-DRIVEN DEVELOPMENT
“なぜこれが問題なのか? これから1分間、開発者が普段テストについてどう考えているか思い浮かべてみよう。プログラマはこう大抵はこう考える。「全部にテストなんて書けないよ」「これは本当に単純なコードだからテストなんて要らないな」「テストなんて時間の無駄だ」「こんなテスト(ループ/データ取得/機能、など)は何百万回もやっ
たよ」”
http://giantech.jp/pages/ikitema2/BDDIntro.html
「テスト」という言葉の力
✦言葉に引っ張られる思考様式
✦「テスト」では語れない意味がTDDのテストにはあると皆が感じていた
✦それに「振舞(Behaviour)」と名前をつけよう!
–Kent Beck
“西欧社会における資源の高度利用は、概して搾取と枯渇によるものである。パーマカルチャーとは、シンプルな実践の相乗効果によって、資源を持続的に高度利用することを目的とした思慮深い農法である。”
–Kent Beck
“これには、XPとの類似点がいくつかある。たとえば、さまざまな要素同士が相互に影響し合うことで最大の収穫が得られる。パーマカルチャーとは、異なる作物を螺旋状に植え、不規則な湖岸線を持つ湖を使うこで、相互作用を最大にすることだ。XPはオンサイト顧客とペアプログラミングによって、相互作用を
最大にする。”
パーマカルチャー
–Wikipedia
“エコロジカルデザイン・環境デザイン分野の用語であり、自然のエコシステムを参考にし持続可能な建築や自己維持型の農業システム
を取り入れ、 社会や暮らしを変化させる 総合的なデザイン科学概念”
–PCCJより
“パーマカルチャーというのは、人間にとっての恒久的持続可能な環境をつくり出すた
めのデザイン体系のことである。 パーマカルチャーという語そのものは、パーマネント(permanent 永久の)とアグリカルチャー(agriculture 農業)をつづめたものであるが、同時にパーマネントとカルチャー(文化)の縮約形でもある。 ”
愛媛出身 福岡正信翁
倫理
倫理(ETHICS)
✦地球への配慮(Earth Care)
✦人への配慮 (People Care)
✦余剰物の分配 (Fair Share)
原則
原則
✦ビル・モリソンとデビット・ホルムグレンで若干異なる
✦今後も見直され変更されるだろう(ホルムグレン)
✦ XPはビル・モリソンの原則を参考にしている
原則✦相互連関的な位置づけ
✦多機能性
✦重要機能のバックアップ
✦効率的なエネルギー計画
✦生物資源の活用
原則✦エネルギー循環
✦小規模集約システム
✦植物の遷移と進化の加速
✦多様性
✦接縁効果
接縁(エッジ)効果
✦エッジはシステムのなかで最も多様な地域になっている。エッジは最も生産性の高いところなので、システム内のエッジを出来るだけ多くするようにデザインする事が必要。
✦海と海岸、平地と丘、池と岸
XPの適応例✦役割と役割
✦顧客とプログラマー
✦ペア・プログラミング
✦部門と部門
✦組織と組織
実践
パーマカルチャーのデザイン
要素 要素
要素と要素を適所に 配置して結びつけ 効果的に機能させる
–Kent Beck
“パーマカルチャーのように考えると デザインとは効果的に関連している
要素のシステムである”
デザインの例
雑草 畑
ニワトリ摂食 耕うん
保湿
肥料
家庭でのデザイン例
残渣
ミミズ
畑
野菜
家庭
排泄物 排水
廃棄
投入
施肥
投入
排泄水利用
水やり栽培
調理
浄化槽投入
–Kent Beck
“非暴力的なコミュニケーションの狙いは、人が判断と観察を区別し、その奥にある必要性を聞き出して、彼ら自身の必要性を明確に述べられるようにすることである。”
NVC勉強会(愛媛)
–Wikipedia
“コミュニケーションにおいて相手とのつながりを持ち続けながら、お互いのニーズが満たされるまで話し合いを続けていくという、共感を持って臨むコミュニケーション
の方法である。”
NVCのプロセス観察
感情
必要としていること (ニーズ)
要求 (リクエスト)
評価を交えずに観察する
どう思っているかではなく どのような感情があるかを読み取る
感情の根源にある 必要としているものを探す
ニーズを満たす 具体的な要求を表現する
• 娘「テストが90点だったよ」
• 私「惜しいね!次は100点目指してね!」
• 娘「90点とったんだから褒めてよ!」
• 娘「テストが90点だったよ」
• 私「凄いね!」
• 娘「100点取れなかったんだよ!」
• 娘「テストが90点だったよ」
• 私「(顔を見て)100点取れなくて悔しいの?」
• 娘「そう、悔しいんだよ!」
• 私「パパにできることはあるかな?」
ユーザーストーリー
【役割】として 【具体的な要求】が欲しい
それは【必要としていること】だからだ
エクスペリエンスマップ
http://www.ajike.co.jp/switch/ux_map/
感情
日常的に使うのはなかなか…
✦難しい。訓練が必要。
✦それでも「なんとかしたい」と思うかどうか
✦心の底から、相手と通じたいと思うかどうか
–Kent Beck
“シンプルさと 明確さの価値について検討している。”
アーミッシュ“米国に住むキリスト教一派のドイツ系アメリカ人で、近代文明を拒否して生活しており、電気、電話などは一切使わず、また基本的に自給自足で生きて
いる人々です。”http://oka-jp.seesaa.net/article/162826592.html
http://plaza.rakuten.co.jp/ranran077/5006/
“問題となるのは選択の正誤ではなかった。 優先するのは何か、次にそのために
何が最適か、が考えられた。”
–Sue Bender
“期待と現実が合致するとき、 人は満足するということなのだろう”
–Sue Bender
“アーミッシュを訪ねる前、私は選択肢が多ければ多いほど自分は豊かだと思っていた。
だが選択肢の多さと、 選択するということはまったく違う。”
–Sue Bender
“選択すること ーこれが大切だと宣言することーーは、 人生の枠組みをつくることであり、
他の可能性を排除し、 残ったものに意味付けをすることである。”
–Sue Bender
–Sue Bender
“古い私はすこしも変わらない。 古い私、新しい私、不完全な私 それらすべてをひっくるめて 受け入れようとする私がある”
まとめ
私が白本と 参考文献に学んだこと
✦ソフトウェア開発の現場で役立つ様々なプラクティスや原則
✦自分が変わることで、世界は変わること
✦よりよい仕事・人生を送るために、自分の内面と向き合うこと
XP
Scrum
Lean
XP
Scrum
Lean
個人
チーム
組織
Even programmers can be whole people in the real world.
プログラマーでさえも全人に成り得る
Think about your values. Make conscious choices to live in
harmony with them.
自分の価値を考え、その価値と調和した生活を 意識的に選択するのだ。
自分の大事なものを見つめて よい仕事・よい人生を XPと共に送りましょう