C言語プログラミング ifdefでデバッグする方法
スポンサーリンク
プログラム開発をする過程で、デバッグをすると思います。
今どのような値が入ってるかを確かめたり、開発中には同じパラメータを使うため、コードの中にハードコードをしておいたり、といったことを多々やります。
デバッグするために printf() を大量に埋め込んだりして、でも、リリースするときには、それらを消したり、コメントアウトしたり、といった作業が必要になったりします。
また再び、開発を再開したときに、同じようなprintf()を埋め込んでいったりして、結構面倒なことをしてるケースもあります。
printf()デバッグをするなといえば、それまでですが、人それぞれ、やり方がありますし、場合によってはそれでよいと思います。
そんなときに、プリプロセッサディレクティブ(ifかifdef)を利用します。
しかしながら、ifdefで制御する場合、ソースコードが読みにくくなるデメリットがあります。
ebug.c
サンプルコード
ifdefを無効にした場合
関連
[2008-06-23-1] C言語プログラミング マクロで可変引数を扱う方法とデバッグprintf
[2008-06-23-2] C言語プログラミング ifdefでデバッグする方法
[2008-06-17-1] C言語 可変引数 va_arg
今どのような値が入ってるかを確かめたり、開発中には同じパラメータを使うため、コードの中にハードコードをしておいたり、といったことを多々やります。
デバッグするために printf() を大量に埋め込んだりして、でも、リリースするときには、それらを消したり、コメントアウトしたり、といった作業が必要になったりします。
また再び、開発を再開したときに、同じようなprintf()を埋め込んでいったりして、結構面倒なことをしてるケースもあります。
printf()デバッグをするなといえば、それまでですが、人それぞれ、やり方がありますし、場合によってはそれでよいと思います。
そんなときに、プリプロセッサディレクティブ(ifかifdef)を利用します。
しかしながら、ifdefで制御する場合、ソースコードが読みにくくなるデメリットがあります。
ebug.c
サンプルコード
#include <stdio.h> #include <stdlib.h> int main (int argc, char *argv[]) { int i; char *p; #if EBUG printf ("[DEBUG] argc=%d\n", argc); #endif #ifdef EBUG p = "localhost"; #else if (argc != 2) { printf ("Usage: a.out hostname\n"); exit (EXIT_FAILURE); } p = argv[1]; #endif for ( i = 0; i < 10; ++i) { #ifdef EBUG printf ("[DEBUG] i=%d\n", i); #endif printf("%s\n", p); } exit (EXIT_SUCCESS); }コンパイル
gcc -DEBUG ebug.c
実行結果
[DEBUG] argc=1 [DEBUG] i=0 localhost [DEBUG] i=1 localhost [DEBUG] i=2 localhost [DEBUG] i=3 localhost [DEBUG] i=4 localhost [DEBUG] i=5 localhost [DEBUG] i=6 localhost [DEBUG] i=7 localhost [DEBUG] i=8 localhost [DEBUG] i=9 localhost
ifdefを無効にした場合
% gcc ebug.c % ./a.out Usage: a.out hostname 1で終了しました % ./a.out foo foo foo foo foo foo foo foo foo foo foo
関連
[2008-06-23-1] C言語プログラミング マクロで可変引数を扱う方法とデバッグprintf
[2008-06-23-2] C言語プログラミング ifdefでデバッグする方法
[2008-06-17-1] C言語 可変引数 va_arg
参照しているページ (サイト内): [2008-06-23-2] [2008-06-23-1] [2008-06-17-1]
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12