装逼利器之DLog -DEBUG
#ifdef DEBUG
#define DLog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);
#else
#define DLog(...)
#endif
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相关推荐
- 程序员装逼利器之impress.js
impress.js是一个javascript的第三方类库,可以实现ppt,动画,切换等功能,在所有的web浏览器上均有不错表现,但目前不支持手机浏览器. 下载地址: https://githu ...
- Eclipse 使用的装逼神器之 Eclipse 全屏模式
< Eclipse 全屏模式 > 关于Eclipse : Eclipse 是一个开放源代码的.基于Java的可扩展开发平台.就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发 ...
- python利器怎么编程-Python任务调度利器之APScheduler详解
任务调度应用场景 所谓的任务调度是指安排任务的执行计划,即何时执行,怎么执行等.在现实项目中经常出现它们的身影:特别是数据类项目,比如实时统计每5分钟网站的访问量,就需要每5分钟定时从日志数据分析访问 ...
- java项目黑科技_这些Java编程黑科技,装逼指南,高逼格代码,让你惊叹不已
Javascript是一门很吊的语言,我可能学了假的JavaScript,哈哈,大家还有什么推荐的,补充送那啥邀请码. 这篇文章共享之前我仍是要引荐下我自个的前端群:657137906,不论你是小白仍 ...
- Android+Web视频直播装逼实现
一.前言 因为最近视频直播比较火,自己也想去了解,所以看了一些资料分享一下,说错了的请大家包容和指正. 二.实现原理 看图说话: 通过上图可以看到,所谓的视频直播其实就是通过录相设备将采集到视频数据以 ...
- 装逼一步到位!GauGAN代码解读来了
↑↑↑关注后"星标"Datawhale 每日干货 & 每月组队学习,不错过 Datawhale干货 作者:游璐颖,福州大学,Datawhale成员 AI神笔马良 如何装逼一 ...
- 代码 抠图_Python装逼指南——五行代码实现批量抠图!
你是否曾经想将某张照片中的人物抠出来,然后拼接到其他图片上去,从而可以即使你在天涯海角,我也可以到此一游?专业点的人使用 PhotoShop 的"魔棒"工具可以抠图,非专业人士可以 ...
- python利器的使用-图文详解python开发利器之ulipad的使用实践
Ulipad是一个国人limodou编写的专业Python编辑器,它基于wxpython开发的GUI(图形化界面).下面这篇文章主要介绍了python开发利器之ulipad的使用实践,文中介绍的非常详 ...
- JavaScript装逼指南
如何写JavaScript才能逼格更高呢?怎样才能组织JavaScript才能让别人一眼看出你不简单呢?是否很期待别人在看完你的代码之后感叹一句"原来还可以这样写"呢?下面列出一些 ...
最新文章
- 还没用上 JDK 11吧,JDK 12 早期访问构建版使用
- java mytable_Mybatis-Plus之@TableField字段
- 深入理解java SPI机制
- java 死锁的检测与修复_调查死锁–第4部分:修复代码
- 聚数引智,承德大数据产业对接交流会将于2019中国国际数字经济博览会期间召开...
- WSL2 下的 Docker 配置,使用网易云镜像 + 更改 docker 文件系统(否则无法 apt update)
- 【Python3 爬虫】12_代理IP的使用
- [转]C#中的多线程进度条使用
- 经典案例 | I-SPY2乳腺癌药物临床试验采用RPPA技术建立药物响应相关分子分型
- 免费开源平台 CESIUM GIS、Worldwind、skyline、mapgis、mapinfo、ARCGIS、OSGEARTH、UNIGINE、unity3d、ossimplant
- 如何理性的调整「rwnd」和「cwnd」的大小
- Milvus 群星闪耀时|又一个小目标达成 :社区正式突破 15,000 星!
- Docker教程(1)Docker 入门
- JavaScript具有自动垃圾回收机制
- Cordova开机画面
- spring项目中使用slf4j和log4j2日志框架
- 【财富空间】将门CEO高欣欣、顺丰首席科学家刘志欣、图灵机器人联合创始人杨钊、中国人民大学向松祚等——AI应用落地:用产品说话
- 快手广告投放方式有哪些?快手广告怎么计费的?
- [Linux] date命令
- 『题解』洛谷P2357 守墓人