本記事は、 ギルドワークスAdventCalendar 17日目の記事です。
とうとうリファクタリング第二版が発売です!
先月末に、とうとうリファクタリングの第二版が、原著にて発売されました!もともと1999年に発売された本ですから、およそ20年ぶりの改版となります。
日本でも Amazonで買えます!
現状刊行されているのは英語ですが、シンプルな表現が多いのと、コード例も多いので素直に読めるのではないのでしょうか。また、おそらく2019年のはじめには、日本語訳版もでるのではないでしょうか。
というわけで、中身をちょっとだけ先取りしてみましょう。
第二版で増えた「不吉な臭い」
気になるのは皆さん、第一版との差分ですよね。そのなかでも、本書の根幹をなすのが、「コードの不吉な臭い(Code Smells)」です。そこでここでは、「臭い」に着目して、差分を見てみたいと思います。

追加された不吉な臭い①: 不可思議な名前(Mysterious Name)
まず最初に追加されたのは、「不可思議な名前」です。つかされたばかりか、これは全ての不吉な臭いに先立つものとして追加されています。
そう、名前付けは「 コンピューター科学での二大難問 」のひとつなのです。
追加された不吉な臭い②: グローバルデータ
グローバルデータとは、プログラムのどこからでもアクセスでき、変えられるものです。グローバル変数はもちろんそうですが、リファクタリングではシングルトンやクラス変数もグローバルデータとして挙げられています。
追加された不吉な臭い③: 変更可能なデータ
データの変更は基本的にはさけるべきこととして明示されるようになりました。データが変更できるということは、それ変更を知らずにのほほんと生きているオブジェクトがある、ということになります。これは非常に危険な兆候、ということですね。
追加された不吉な臭い④: ループ
第二版での大きな変更のポイントが個々ではないでしょうか。ループというのはfor文だけではなく、 Range Based For や foreach のような、安全性の高いループも対象になっています。長い間、プログラムの中心を担ってきたループ構文ですが、関数オブジェクトがほとんどの言語で簡単に使えるようになった今、その役目を終えようとしているのでしょう。
このように、モダンな言語向けにアップデートされたリファクタリングの第二版、冬休みのお供にぜひ読んでみてはいかがでしょうか。
この記事もどうですか?
-
うまくなるための”やること”リストが増えて時間が足りない時の対処
状況 ふりかえりなどで「どうしたらもっとうまくできるか?」を話し合っている。 困り事 「うまくできるか?」に対してやることが増えて、時間が十分に取れない。 こうやってみる 「うまくできるか?」を試すのは 1度に1つずつ にしてみる。同時にい…
-
ユーザーインタビューのスタイルを学べる、かもしれないテレビ番組3選
ギルドワークスの佐々木です。 はじめに ユーザーエクスペリエンスデザインや仮説検証を進めていこうというチームが増えてきています。 そんな中、インタビューをやったことがない、インタビューをどう進めていいか分からない、といった声をよく聞きます。…
- 仮説検証
-
プログラマなら「道具」に愛着を持とう
プログラマという仕事は、「職人」と例えられることが多いのではないかと思います。確かに、凄腕のプログラマの方の仕事に対する凄みは、熟練の職人を思わせるものが多いです。 そんな職人の方たちに共通していると感じるのが、「道具」への愛着です。例えば…