#ifdef DEBUG

#define DLog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);

#else

#define DLog(...)

#endif

DLog的使用

Objective C中NSLog虽然使用方便,但是有时候NSLog并不能满足程序员调试程序的全部需求。比如打印的结果位于哪个类中?是在哪个类中打印的?或者具体是在哪行打印的等等。所以对于程序员来说急切需要可以满足上述要求的Log方法。

DLog就可以完全替代NSLog,并且满足上述的需求。DLog本质上就是个宏替换,可以输出类名,方法名和行号。DLog具体代码如下:

#ifdef DEBUG

#define DLog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);

#else

#define DLog(...)

#endif

将以上代码写到prefix.pch文件中,并且在工程Bulid Settings的other C Flags的Debug中加入-DDEBUG就可以在代码中的任何位置使用DLog了。

因为是在Debug模式下加入DLog,所以在Release版本中不会加入DLog代码

简单介绍以下几个宏:

1) __VA_ARGS__ 是一个可变参数的宏,这个可变参数的宏是新的C99规范中新增的,目前似乎只有gcc支持(VC6.0的编译器不支持)。宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉,否则会编译出错。

2) __FILE__ 宏在预编译时会替换成当前的源文件名
3) __LINE__宏在预编译时会替换成当前的行号
4) __FUNCTION__宏在预编译时会替换成当前的函数名称

例如:DLog(@"mcoudeFlag:%d",mCodeFlag);

有程序的地方就有bug,有bug的地方就需要debug。对于程序员来说,coding的过程便是制造bug和解决bug。Objective定义了不少表达式来协助debug的流程,将这些表达式用在NSLog中,可以简化部分工作,快速定义到debug的部分。 比如以下代码

- (id)initWithCoder:(NSCoder *)aDecoder

{

if (self = [super init]) {

NSLog(@"\n function: %s\n Pretty function: %s\n line: %d\n file: %s\n", __func__,__FUNCTION__,__LINE__,__FILE__);

}

return self;

}

运行结果如图:

__func____PRETTY_FUNCTION____LINE____FILE__等都是系统预留的定义词,简单易用

另外有一些Core Foundation的方法可以从CFString的层级拿到一些有用的字符串,包括且不限于selector,class,protocol等,参考下面的代码:

- (id)initWithCoder:(NSCoder *)aDecoder

{

if (self = [super init])

{

//        NSLog(@"\n function: %s\n Pretty function: %s\n line: %d\n file: %s\n", __func__,__FUNCTION__,__LINE__,__FILE__);

NSLog(@"Current selector: %@",NSStringFromSelector(_cmd));

NSLog(@"Object class: %@",NSStringFromClass(self.class));

NSLog(@"Filename: %@",[[NSString stringWithUTF8String:__FILE__] lastPathComponent]);

}

return self;

}

运行结果如图:

拿到了相关的字符串,其实这并不仅在调试中有用,在进行selector的传递时也很好用~

转载于:https://www.cnblogs.com/OIMM/p/5325491.html

装逼利器之DLog -DEBUG相关推荐

  1. 程序员装逼利器之impress.js

    impress.js是一个javascript的第三方类库,可以实现ppt,动画,切换等功能,在所有的web浏览器上均有不错表现,但目前不支持手机浏览器. 下载地址:    https://githu ...

  2. Eclipse 使用的装逼神器之 Eclipse 全屏模式

    < Eclipse 全屏模式 > 关于Eclipse : Eclipse 是一个开放源代码的.基于Java的可扩展开发平台.就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发 ...

  3. python利器怎么编程-Python任务调度利器之APScheduler详解

    任务调度应用场景 所谓的任务调度是指安排任务的执行计划,即何时执行,怎么执行等.在现实项目中经常出现它们的身影:特别是数据类项目,比如实时统计每5分钟网站的访问量,就需要每5分钟定时从日志数据分析访问 ...

  4. java项目黑科技_这些Java编程黑科技,装逼指南,高逼格代码,让你惊叹不已

    Javascript是一门很吊的语言,我可能学了假的JavaScript,哈哈,大家还有什么推荐的,补充送那啥邀请码. 这篇文章共享之前我仍是要引荐下我自个的前端群:657137906,不论你是小白仍 ...

  5. Android+Web视频直播装逼实现

    一.前言 因为最近视频直播比较火,自己也想去了解,所以看了一些资料分享一下,说错了的请大家包容和指正. 二.实现原理 看图说话: 通过上图可以看到,所谓的视频直播其实就是通过录相设备将采集到视频数据以 ...

  6. 装逼一步到位!GauGAN代码解读来了

    ↑↑↑关注后"星标"Datawhale 每日干货 & 每月组队学习,不错过 Datawhale干货 作者:游璐颖,福州大学,Datawhale成员 AI神笔马良 如何装逼一 ...

  7. 代码 抠图_Python装逼指南——五行代码实现批量抠图!

    你是否曾经想将某张照片中的人物抠出来,然后拼接到其他图片上去,从而可以即使你在天涯海角,我也可以到此一游?专业点的人使用 PhotoShop 的"魔棒"工具可以抠图,非专业人士可以 ...

  8. python利器的使用-图文详解python开发利器之ulipad的使用实践

    Ulipad是一个国人limodou编写的专业Python编辑器,它基于wxpython开发的GUI(图形化界面).下面这篇文章主要介绍了python开发利器之ulipad的使用实践,文中介绍的非常详 ...

  9. JavaScript装逼指南

    如何写JavaScript才能逼格更高呢?怎样才能组织JavaScript才能让别人一眼看出你不简单呢?是否很期待别人在看完你的代码之后感叹一句"原来还可以这样写"呢?下面列出一些 ...

最新文章

  1. 还没用上 JDK 11吧,JDK 12 早期访问构建版使用
  2. java mytable_Mybatis-Plus之@TableField字段
  3. 深入理解java SPI机制
  4. java 死锁的检测与修复_调查死锁–第4部分:修复代码
  5. 聚数引智,承德大数据产业对接交流会将于2019中国国际数字经济博览会期间召开...
  6. WSL2 下的 Docker 配置,使用网易云镜像 + 更改 docker 文件系统(否则无法 apt update)
  7. 【Python3 爬虫】12_代理IP的使用
  8. [转]C#中的多线程进度条使用
  9. 经典案例 | I-SPY2乳腺癌药物临床试验采用RPPA技术建立药物响应相关分子分型
  10. 免费开源平台 CESIUM GIS、Worldwind、skyline、mapgis、mapinfo、ARCGIS、OSGEARTH、UNIGINE、unity3d、ossimplant
  11. 如何理性的调整「rwnd」和「cwnd」的大小
  12. Milvus 群星闪耀时|又一个小目标达成 :社区正式突破 15,000 星!
  13. Docker教程(1)Docker 入门
  14. JavaScript具有自动垃圾回收机制
  15. Cordova开机画面
  16. spring项目中使用slf4j和log4j2日志框架
  17. 【财富空间】将门CEO高欣欣、顺丰首席科学家刘志欣、图灵机器人联合创始人杨钊、中国人民大学向松祚等——AI应用落地:用产品说话
  18. 快手广告投放方式有哪些?快手广告怎么计费的?
  19. [Linux] date命令
  20. 『题解』洛谷P2357 守墓人

热门文章

  1. 无缝衔接的人会遭报应吗_无缝衔接会有报应吗?
  2. Blender图解教程:如何把外部图片打包到工程文件(*.blend)中
  3. 身份证验证正则表达式
  4. 分享一个公众号h5裂变吸粉源码工具
  5. 项目管理之敲门砖-PMP证书
  6. dSPACE Control Desk 7.2. Platform激活
  7. 《浅谈Cache Memory》 学习-第四章
  8. PDF文件可以转换成Excel文件吗
  9. 席马云(微博)昨日在杭州和黄章会面
  10. 【android】音乐播放器之service服务设计