erlang方便的打印调试信息

目前调试一个模块时比较麻烦,需要重新编译成调试版本,即增加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, []).
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值