Erlang便利な印刷デバッグ情報
1120 ワード
詳細
現在、モジュールをデバッグするのは面倒ですが、デバッグバージョンに再コンパイルする必要があります.つまり、DEBUGマクロまたはdebug_を追加します.infoなどの情報を再コンパイルします.
この効果を達成するには、モジュールをデバッグしたいときにtest:debug()を呼び出して自動的にデバッグモードに変換すると便利です.
効果は次のとおりです.
すると、次のように書くことができます.
現在、モジュールをデバッグするのは面倒ですが、デバッグバージョンに再コンパイルする必要があります.つまり、DEBUGマクロまたはdebug_を追加します.infoなどの情報を再コンパイルします.
この効果を達成するには、モジュールをデバッグしたいときにtest:debug()を呼び出して自動的にデバッグモードに変換すると便利です.
効果は次のとおりです.
Eshell V5.8.3 (abort with ^G)
1> c(test).
{ok,test}
2> test:test(1).
2
3> test:debug().
{ok,test}
4> test:test(1).
test(1) = 2
2
5>
すると、次のように書くことができます.
-module(test).
-compile(export_all).
-ifdef(DEBUG).
-define(LOG(Format), io:format(Format)).
-define(LOG(Format, Data), io:format(Format, Data)).
-else.
-define(LOG(Format), ok).
-define(LOG(Format, Data), ok).
-endif.
test(N) when is_integer(N) ->
R = N + N,
?LOG("test(~p) = ~p~n", [N, R]),
R.
debug() ->
debug(true).
debug(true) ->
c:c(?MODULE, [{d, 'DEBUG'}]);
debug(false) ->
c:c(?MODULE, []).