How to print out the method name and line number and conditionally disable NSLog?(如何打印出方法名称和行号并有条件地禁用 NSLog?)
问题描述
我正在做一个有关在 Xcode 中调试的演示文稿,并希望获得有关有效使用 NSLog 的更多信息.
I'm doing a presentation on debugging in Xcode and would like to get more information on using NSLog efficiently.
特别是,我有两个问题:
In particular, I have two questions:
- 有没有办法轻松 NSLog 当前方法的名称/行号?
- 有没有办法在编译发布代码之前轻松禁用"所有 NSLog?
推荐答案
下面是一些我经常使用的关于 NSLog 的有用宏:
Here are some useful macros around NSLog I use a lot:
#ifdef DEBUG
# define DLog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__)
#else
# define DLog(...)
#endif
// ALog always displays output regardless of the DEBUG setting
#define ALog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__)
DLog 宏仅用于在设置了 DEBUG 变量时输出(项目的 C 标志中的 -DDEBUG 用于调试配置).
The DLog macro is used to only output when the DEBUG variable is set (-DDEBUG in the projects's C flags for the debug confirguration).
ALog 将始终输出文本(如常规 NSLog).
ALog will always output text (like the regular NSLog).
输出(例如 ALog(@"Hello world") )将如下所示:
The output (e.g. ALog(@"Hello world") ) will look like this:
-[LibraryController awakeFromNib] [Line 364] Hello world
这篇关于如何打印出方法名称和行号并有条件地禁用 NSLog?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何打印出方法名称和行号并有条件地禁用 NSLog?
基础教程推荐
- 如何在 iPhone 上显示来自 API 的 HTML 文本? 2022-01-01
- android 应用程序已发布,但在 google play 中找不到 2022-01-01
- 如何在没有IB的情况下将2个按钮添加到右侧的UINavigationbar? 2022-01-01
- Android:对话框关闭而不调用关闭 2022-01-01
- 如何让对象对 Cocos2D 中的触摸做出反应? 2022-01-01
- UIWebView 委托方法 shouldStartLoadWithRequest:在 WKWebView 中等效? 2022-01-01
- 当从同一个组件调用时,两个 IBAction 触发的顺序是什么? 2022-01-01
- 如何在 UIImageView 中异步加载图像? 2022-01-01
- 在 gmail 中为 ios 应用程序检索朋友的朋友 2022-01-01
- Kivy Buildozer 无法构建 apk,命令失败:./distribute.sh -m “kivy"d 2022-01-01