現実世界のプログラミングにおけるマクロ乱用の落とし穴
マクロとプリプロセッサは C プログラミングで重要な役割を果たし、次のような機能を提供します。テキスト置換を定義し、コード生成を実行します。ただし、最悪のマクロ乱用を示す実際の例で証明されているように、その過度の使用は多くの課題を引き起こす可能性があります。
プログラマーが、次のような理由でバイト最適化を執拗に追求するシナリオを考えてみましょう。メモリに制約のあるシステムに関するこれまでの経験から、型破りなアプローチに頼っていました。この個人は、RETURN という名前のマクロを次のように定義しました。
#define RETURN(result) return (result);}
このマクロは、閉じ中括弧なしでいくつかの関数を定義するために使用され、次のようなコードベースになりました。
int myfunction1(args) { int x = 0; // do something RETURN(x) int myfunction2(args) { int y = 0; // do something RETURN(y) int myfunction3(args) { int z = 0; // do something RETURN(z) }
この極端なマクロの悪用により、構文の強調表示が著しく損なわれ、関数とコード ブロックを視覚的に区別することが不可能になってしまいます。このプログラマーがこのアプローチを正当化したのは、アセンブリ言語を扱う中で磨かれた、バイトの節約が最優先であるという、深く根付いた考え方に由来しています。
この人物に関連した他の奇行は、極端なプログラミング手法の潜在的な結果をさらに浮き彫りにしました。モニターの上に戦略的に配置された凸面鏡は、傍観者の存在を検出するための基本的な監視システムとして機能しました。さらに、コンパイラーがコード内でエラーを検出したときは常に、椅子から突然立ち去り、続いて簡単な腕立て伏せを繰り返すことが、自己罰の一種として使用されていました。
この例は、過度の危険性についての警告として機能します。マクロの悪用。マクロは特定のシナリオで一定の利点を提供しますが、無差別に使用すると、コードベースの読み取り、保守、デバッグが困難になる可能性があります。
以上がマクロの悪用により、コードが読み取れなくなったり、保守不可能になったりするのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。