InfoQ

News

ソフトウェアの型 - 公の場で練習することで完璧になる

作者 Cory Foy , 翻訳者 南 伸二 投稿日 2009年12月11日 午後3時0分

コミュニティ
Agile
トピック
設計,
アジャイル技術,
トレーニング/認証

原文(投稿日:2009/11/26)へのリンク

アジャイルコミュニティの思慮深きリーダーたちが、ソフトウェアの型 - 体にしみこむまで特定の練習を行う方法 - についてかなり語りはじめている。ここ数週間にわたって、型について論じているブログの投稿やサイトは増えている。Robert Martin氏はそれを"パフォーマンスアート"であると呼ぶくらいにまでなっている。あなたは型を自分のソフトウェアツールキットに取り入れるべきなのだろうか?

およそ2年ほど前、InfoQでは幅広い話題 - そこには型も含まれている - に関して"達人" Dave Thomas氏にインタビューを行った。型は、記憶することを目的とした訓練の集中的な手順である。それぞれの型は特定の問題の解決策となっている。例えば:ボウリングのゲームでスコアを記録するものや、数字をLCDの形式に変換するもの、そして、素因数を見つけ出すものなどがある。

先週の初め、Uncle Bob氏は型に関するいったい型のどこがばかげたものなのかというタイトルのブログの投稿において型について 書いている。そして、10月の中旬には、Corey Haines氏とソフトウェア職人コミュニティの人たちがkatas.softwarecraftsmanship.orgという毎週いろいろな型のスクリーンキャストを投稿するサイトを立ち上げた。

そこにさらにもう一歩踏み込んでみてみると、Uncle Bob氏は彼の最新の型を投稿しており、その中で彼は花のデュエットという歌に合わせて素因数を見つけるソリューションを構築している。彼は記事の中で、プログラミングをパフォーマンスアートになぞらえながら、次のように述べている:

実際、熟練し十分に訓練された武道家が型を演じるのをみることは美しいことなのです。そして、そこから私は考え始めました。どうして武道家はそのような手順を芸術として演じられるほどまでに情熱的に訓練するのだろうか、と。

その後で、彼は次のように続けている:

熟練した武道家が演ずるのを見てしまうと、彼と戦おうとは思わなくなるはずです。その実演は熟達していることのデモンストレーションであり、そして現実化なのです。

そしてさらに…どんな武道家もステージの上で演ずることができるようになるために武道の訓練をしたりしません。武道家は護身の技を自ら完璧にするために訓練に励むのです。訓練を演じることができるという事実は、(喜ばしい)副作用なのです。

あなたはどんな方法でコーディング技術を訓練するだろうか? 型や、あなたが作業している詳細に関するスクリーンキャストをつくったことがあるだろうか? あなたが使ってるお気に入りのサイトや型はあるだろうか? 下のコメント欄で私たちに教えて欲しい!

(この投稿をDeborah Preuss' European XPDaysツアーの間に書いてくれたCory Foy氏に感謝する。)

ブックマーク
digg+,
reddit+,
del.icio.us+,
dzone+,
slashdot+
Hatena

特集コンテンツ一覧

アジャイルにおけるプロジェクトマネジャーの役割

この記事では最初に一般的に産業界でのプロジェクトマネージャーの役割について説明し、それから、アジャイルにおけるコーチ/ファシリィテーターの役割にあてはめてみます。

アレグザンダー祭りにて、James.O.Coplienが語るアジャイルとスクラムの源流とは

「パターン」と呼ばれる設計手法をご存知ですか?この建築の分野ではじまった設計の形式知化手法、および、使う人と作る人の対話のプロセスは、私たちソフトウェアの世界に援用されて1995年に「デザインパターン」という書籍で注目を浴びました。さらに、アジャイルと呼ばれる開発手法には、ユーザーといっしょに対話をしながら設計を進める「パターン」の思想が脈々と引き継がれているのです。

仮想パネル:ソフトウェアアーキテクチャの文書化について

この仮想パネルでは、特に、アジャイルソフトウェア開発環境におけるソフトウェアアーキテクチャの文書化について、Len Bass氏、Grady Booch氏、Paulo Merson氏、Eoin Woods氏に話を聞いた。

HTTPSコネクションの最初の数ミリ秒

HTTPSコネクションを確立するとき、一体何が起こっているのだろう。この記事では安全なコネクションを準備するためにクライアントとサーバの間でどのようなデータの交換が行われているのか、バイトレベルまで詳細に分析する。

Modular Java:動的なモジュール化

Modular Javaシリーズの第3弾は、動的なモジュール化、どのようにバンドルのクラスが解決され、どのように生成され、消滅するのか、どのようにお互いに通信するのかについて、議論する。

分散バージョン管理システムの詳細なガイド

分散バージョン管理システムへの関心や採用は増え続けています。この記事では、分散バージョン管理システムのコンセプトを紹介し、git、Mercurial、Bazaarの3つについて詳しく見てみようと思います。

Modular Java:それは何なのか?

ここ数年にわたって、Javaのモジュール化は活発に議論され続けている話題である。いくつかのJSRによってJavaの進化におけるモジュール化の必要性が示されている。モジュール化の意味するところは何で、なぜそれを気にかけるべきなのだろうか?

Modular Java:静的なモジュール化

Modular Javaシリーズの第2弾は、静的なモジュール化、バンドルの作り方、OSGiのエンジンにそれらをインストールする方法、バンドル間の(バージョン付き)依存性の設定のしかたなどについて扱う。