汚いコードとは何か?
ガジェット通信 / 2012年12月22日 14時0分
今回はメカAGさんのブログからご寄稿いただきました。
■汚いコードとは何か?
プログラミングを知らない人には、プログラマが言う「汚いコード」というものが実感できないかもしれない。それをシンプルに説明してみる。
たとえば円周率の3.14。円周率を使って円の面積を求めるプログラムが組まれているとする。3.14という数字が書かれているコードがある。
それがどうしたの?と思うかもしれない。ところがこのコードは汚いのだ。「え?なぜ?!」というのが、非プログラマの反応だろう。
もっと精度よく計算するために3.1415を使いたくなったとする。その場合、それまで3.14だったところを3.1415に修正するわけだが、プログラムが巨大になると、その箇所は膨大になる。どこかを修正し忘れたりする。
ある場所では3.14で計算し、別な箇所では3.1415で計算すると、同じになるはずの数値が同じにならない。これをバグという。
* * *
ではどうすればいいか。プログラムのある箇所で「PI=3.14」と定義すればいい。そしてそれ以外の箇所ではPIを使い、絶対3.14という数値を使わないことに「決める」。
そうすればPI=3.14の箇所だけ「PI=3.1415」と修正すれば、全部直るわけだ。直し忘れもなくなる。
ところがある箇所ではPIを使い、別な箇所では3.14をそのまま使っていたりすると、PI=3.1415と修正した瞬間に、そのプログラムは正常には動かなくなってしまう。
つまりPIと書いてあったり、3.14と書いてあったり、はたまた別の箇所では3.141とか書いてあるプログラムは「汚い」のだ。
* * *
3.14ぐらいコードを検索すればいいんじゃない?と思った人!たとえば6.28という数値が使われていたらどうだろう。もちろん6.28=3.14*2だ。でも3.14を検索しても6.28は見つからない。円周の計算ではこちらの数値のほうが頻繁に出てくるかもしれない。
* * *
これを読んで多くの人は、じゃあ、ちゃんと「3.14を使わずにPIを必ず使いましょう」「6.28を使わずに(PI*2)を使いましょう」と、みんなで約束を決めて守ればいいじゃん、と思うことだろう。その通り!つまりそれが「綺麗にコードを書く」ということなのだ。
え?そんな単純なこと?と思うかもしれない。もちろん現実はこんなに単純じゃない。
* * *
たとえばコピペ。あちこちから使えそうなコードを切り貼りして組み合わせる。確かに手間を省ける。でもあちこちから持ってくるから、ある箇所は3.14を使っていて、別な箇所は3.1415を使っていたりする。定数の定義も「PI」だったり「PIE」だったりする。
プログラムは一見動いているけれど、なんかちょっとおかしい。微妙に計算が合わない。そんな感じになる。コピペで作ったプログラムというのは、大雑把な形になるのは早いが、バグがなかなか取りきれないというのは、こういうこと。
誰かが書いた膨大なコードをちゃんとチェックして、円周率が同じ値に統一されているかを確認する作業は結構大変で、場合によっては自分で書いたほうが早いし確実ということもある。
* * *
単純過ぎて実感がわかない?じゃあ具体例。
惨憺たる評価だった某オンラインゲーム。何かとサーバーがダウンすることで多くのユーザーの不評を買った。おそらく通信エラーの処理をしていなかったと思われる。
社内でテストした時はLANだから安定していて、通信エラーが起きなかったのだろう。でも正式リリースして世界中のPCとインターネット越しに通信するようになると、いろいろな理由で通信エラーは起きる。
通信エラーが起きることを前提にプログラムをしていないと、内部のデータが矛盾してしまい、サーバーが止まってしまう。エラー処理というのは命綱のようなもの。「なくてもとりあえず動くからいいや」と手を抜くと、必要な状況になったときに悔やんでも悔やみきれない。
* * *
しかもエラー処理というのは、後から付け加えて済ませることができるようなしろものではない。ときどきオマケみたいに考えている人がいるけれど、実は一番複雑な部分。時には設計全体の方向性を決定づけてしまうほど。
銀行の送金で途中でエラーが起こった場合、お金がどこにもなくなってしまっては困る。かといって両方の口座に残っていても困る。送金が完全に完了するか、送金が全く行われないか、どちらかでないといけない。これはトランザクション処理といってコンピュータサイエンスの一分野。
まずエラー処理はなしである程度作って、後から付け加えようというものではないのだ。
執筆: この記事はメカAGさんのブログからご寄稿いただきました。
【関連ニュース】
この記事に関連するニュース
-
「なぜ円の面積は半径×半径×円周率なのか」東大のベストセラー教授が教える文系も歓喜の"円周率のヒミツ"
プレジデントオンライン / 2025年1月30日 8時15分
-
電車が止まる可能性も?実は深刻な「2038年問題」 社会インフラや家電など広範囲で影響大の恐れ
東洋経済オンライン / 2025年1月30日 8時0分
-
iOS 18.3配信開始 バグ修正のほか、計算機アプリで等号をもう1度タップすると最後の演算を繰り返せるように
ASCII.jp / 2025年1月28日 3時30分
-
「数字が苦手」のほとんどは思い込み…2万人の数字嫌いを救った専門家が研修で行う"エクササイズ"の中身
プレジデントオンライン / 2025年1月20日 15時15分
-
話題の『#100日チャレンジ 毎日連続100本アプリを作ったら人生が変わった』著者・大塚あみさんインタビュー
ASCII.jp / 2025年1月14日 9時0分
ランキング
-
1X、「コミュニティ」の投稿が誰にでも表示される仕様変更 ユーザー当惑「最悪のアプデ」
ITmedia NEWS / 2025年2月4日 19時13分
-
2現役の情シスが考える、KDDIのビジネスPC向け“月額費用なし”データ使い放題サービス「ConnectIN」の強み
ITmedia PC USER / 2025年2月4日 12時40分
-
3ラップの空箱は捨てないで! “目からウロコ”な活用法が240万再生 「天才だ…」【リメイク】
ねとらぼ / 2025年2月4日 7時30分
-
4ニットの収納“生地が伸びる問題”を解決 目からウロコの裏ワザに「その手は思いつかなかった」「やってみます」
ねとらぼ / 2025年2月4日 7時30分
-
5情報セキュリティ10大脅威2025年版が公開 新たに加わった2つの脅威に注目
ITmedia エンタープライズ / 2025年2月4日 7時15分
記事ミッション中・・・
記事にリアクションする
記事ミッション中・・・
記事にリアクションする
エラーが発生しました
ページを再読み込みして
ください