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

追加された不吉な臭い①: 不可思議な名前(Mysterious Name)
まず最初に追加されたのは、「不可思議な名前」です。つかされたばかりか、これは全ての不吉な臭いに先立つものとして追加されています。
そう、名前付けは「 コンピューター科学での二大難問 」のひとつなのです。
追加された不吉な臭い②: グローバルデータ
グローバルデータとは、プログラムのどこからでもアクセスでき、変えられるものです。グローバル変数はもちろんそうですが、リファクタリングではシングルトンやクラス変数もグローバルデータとして挙げられています。
追加された不吉な臭い③: 変更可能なデータ
データの変更は基本的にはさけるべきこととして明示されるようになりました。データが変更できるということは、それ変更を知らずにのほほんと生きているオブジェクトがある、ということになります。これは非常に危険な兆候、ということですね。
追加された不吉な臭い④: ループ
第二版での大きな変更のポイントが個々ではないでしょうか。ループというのはfor文だけではなく、 Range Based For や foreach のような、安全性の高いループも対象になっています。長い間、プログラムの中心を担ってきたループ構文ですが、関数オブジェクトがほとんどの言語で簡単に使えるようになった今、その役目を終えようとしているのでしょう。
このように、モダンな言語向けにアップデートされたリファクタリングの第二版、冬休みのお供にぜひ読んでみてはいかがでしょうか。
この記事もどうですか?
-
大工から引き継がれたソフトウェア職人気質
ソースのdiffを取るように、キャリアのdiffを取る 数年に1度は改訂する個人ドキュメントに、 職務経歴書 があると思います。ドキュメントとしては書くのにたいへん面倒な部類に入りますが、1回作っておくと後は更新で済むので、便利ですね。私が…
-
リーダーシップを取る人はプロジェクトの途中で変わってもいい
リーダーとは一度決まればずっと変わらないもの? チームでプロジェクトにあたる際に「リーダー」と呼ばれる人がいると思います。このリーダーはどのようにして決まっているのでしょうか?社内での肩書き?経験年数?これから挑むプロジェクトへの理解度でし…
-
価値探索とUXデザイン・その3:ユーザーの体験の流れを理解する
この記事は、 ギルドワークス アドベントカレンダーの8日目の記事です。 はじめに 前回の記事(インタビューで他者の世界を理解する)では、インタビューについて紹介しました。インタビューの結果を分析する方法はいくつかありますが、多くの場合はスト…