WEB开发网      濠电娀娼ч崐濠氬疾椤愶附鍋熸い鏍ㄧ〒闂勫嫰鏌﹀Ο渚Ц闁诲氦顕ч湁婵犲﹤楠告禍鍓х磼鏉堛劌绗氶柟宄版嚇閹晠宕归銈嗘濠电偞鍨堕幐鎾磻閹捐秮褰掓偐閻戞﹩妫勯梺鎼炲妼鐎涒晝绮嬪澶樻晝闁挎繂鏌婇敃鍌涚厵閻庢稒锚閻忥絾绻濇繝鍐ㄧ伌闁诡垰鍟村畷鐔碱敂閸♀晙绱樺┑鐐差嚟婵儳螞閸曨剚鍙忛柍鍝勬噹缁€澶嬬箾閹存繄锛嶆鐐灲閹綊宕惰濡插鏌涢妸銉ヮ劉缂佸倸绉归弫鎾绘晸閿燂拷 ---闂備焦瀵уú鈺呭箯閿燂拷
开发学院手机开发iPhone 开发 iPhone仅在 Debug 模式下编译的 NSLog 阅读

iPhone仅在 Debug 模式下编译的 NSLog

 2010-06-19 18:40:00 来源:WEB开发网 闂備線娼уΛ鎾箯閿燂拷闂備礁鎲¢崹鐢垫崲閹扮増鍎嶆い鎺戝€甸崑鎾斥槈濞嗗秳娌紓鍌氱▌閹凤拷濠电姭鎷冮崨顓濈捕闂侀潧娲ゅú銊╁焵椤掍胶鈯曢柕鍥╁仧缁辩偤鏁撻敓锟�闂備線娼уΛ鎾箯閿燂拷  闂備胶枪缁绘鈻嶉弴銏犳瀬闁绘劖顐煎☉妯锋瀻闁归偊鍓涘▔姘舵⒑閸涘⿴娈旀繛灞傚妼閳绘捇骞嬪┑鎰濡炪倖姊婚崢褏鎲撮敓锟�
核心提示:在开发和调试的时候,NSLog() 是一个非常有用的工具,iPhone仅在 Debug 模式下编译的 NSLog,但是即便设定编译配置为 Release,NSLog() 的代码也会被编译到最终文件中,debug_NSLog() 宏才会产生实际的代码,PS: 程序里面的 NSLog() 要全部替换为 debug_NSLo

在开发和调试的时候,NSLog() 是一个非常有用的工具。但是即便设定编译配置为 Release,NSLog() 的代码也会被编译到最终文件中,这显然不是个好消息。

利用 C 的宏特征,可以很简单的解决此问题。

首先新建一个 Debug.h 文件,内容如下:

1.#ifdef DEBUG

2.#define debug_NSLog(format, ...) NSLog(format, ## __VA_ARGS__)

3.#else

4.#define debug_NSLog(format, ...)

5.#endif

然后设定当前激活的配置为 Debug,接着选择菜单“Project -> Edit Active Target”,打开设定对话框:

在 Build 标签中可以找到预定义宏,这里应该有一项 DEBUG,如果没有则添加上。

这样设定后,仅在使用 Debug 配置编译时,debug_NSLog() 宏才会产生实际的代码。

PS: 程序里面的 NSLog() 要全部替换为 debug_NSLog()。

转载,原文地址 http://www.dualface.com/?p=240

Tags:iPhone Debug 模式

编辑录入:coldstar [复制链接] [打 印]
赞助商链接