iOS打印Debug日志的方式
来源:互联网 发布:ios 保存数据到沙盒 编辑:程序博客网 时间:2024/05/17 06:17
转自:http://blog.csdn.net/lixuwen521/article/details/7675836
简单介绍以下几个宏:
1) __VA_ARGS__ 是一个可变参数的宏,这个可变参数的宏是新的C99规范中新增的,目前似乎只有gcc支持(VC6.0的编译器不支持)。宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉,否则会编译出错。
2) __FILE__ 宏在预编译时会替换成当前的源文件名
3) __LINE__宏在预编译时会替换成当前的行号
4) __FUNCTION__宏在预编译时会替换成当前的函数名称
1.重新定义系统的NSLog,__OPTIMIZE__ 是release 默认会加的宏
- #ifndef __OPTIMIZE__
- #define NSLog(...) NSLog(__VA_ARGS__)
- #else
- #define NSLog(...){}
- #endif
2.直接自己写#define,当release版本的时候把#define 注释掉即可
#define IOS_DEBUG
- #ifdef IOS_DEBUG
- #define NSLog(...) NSLog(__VA_ARGS__)
- #endif
3.
- #ifdef DEBUG
- # define DLog(format, ...) NSLog((@"[文件名:%s]" "[函数名:%s]" "[行号:%d]" format), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);
- #else
- # define DLog(...);
- #endif
这种方式需要修改项目的配置,使得在debug编译的时候,编译DLog的宏,产生详细的日志信息,而release的时候,不产生任何控制台输出
相比而言,还是第一种比较方便
0 0
- iOS打印Debug日志的方式
- iOS打印Debug日志的方式
- iOS打印Debug日志的方式
- 打印debug级别的日志
- 黑马程序员-IOS学习笔记 c语言 DEBUG 日志打印
- c语言 DEBUG 日志打印
- Android中日志信息的打印方式
- java 打印日志的几种方式
- xshell打印日志的两种方式
- java 打印日志的几种方式
- java打印日志的几种方式
- iOS 10打印 无关的日志
- iOS 打印日志
- Ios日志打印
- IOS自定义打印日志
- iOS控制打印日志
- IOS日志打印
- iOS iOS10 打印日志
- 大整数乘法(简单模拟乘法过程)
- avcodec_decode_video2少帧问题
- 黑马程序员--面向对象--1st day
- getsockname函数与getpeername函数的使用
- windows环境下YOURLS安装与部署
- iOS打印Debug日志的方式
- logdump
- 操作系统之内存
- Intent进阶 和 Intent-filter 学习笔记
- VHDL设计简单数字时钟
- Httpclient
- Java集合类的使用
- debian安装tomcat
- dispatch基础