[调试相关]预编译文件中宏定义打印日志
来源:互联网 发布:python 日志时间格式 编辑:程序博客网 时间:2024/06/06 09:23
工程有Debug Version和Release Version,Debug Version是程序开发过程中版本,它包含了所有调试信息,一些常用的NSLog打印日志,在程序调试过程工根据我们设置的调试信息可以看出什么地方出错,我们在运行运行一个小程序的时候,会不会首先就想到进行断点调试呢,应该是首先想着NSLog一下,看看哪个函数方法没执行,看看是不是哪个数组的值没取出来。Release Version是发布版本,不打印NSLog可以加快程序运行速度,减少内存使用。 但是到一个大工程中,会有很多很多这样的NSLog,在我们工程完美运行的时候,发布Release 版本的时候,难道我们去一行行的注释调NSLog吗?假如工程现在原来基础上发布一个version 1.2版本的,我们在修改程序的时候岂不是还把原来注释给取消,那就很麻烦很麻烦了。所以,此处用到了宏指令
#ifdef DEBUG#define NSLog(...) NSLog(__VA_ARGS__)#define debugMethod() NSLog(@"%s", __func__)#else#define NSLog(...)#define debugMethod()#endif
上段代码的意思就是 用宏指令做一个判断,如果DEBUG为真,则编译#ifdef到#endif宏定义,否则编译器就不编译;
这个DEBUG在哪设置呢,
在 “Target > Build Settings > Preprocessor Macros > Debug” 里有一个”DEBUG=1”。
现在我们来做一个测试:
取一个宏指令放到OSAppDelegate.m的application:didFinishLaunchingWithOptions:方法中,并用同一个NSLog做一个对比;
NSLog(@”%s”, func);
debugMethod();
首先设置为Debug模式下,Product–>Edit Scheme
跳转到这个界面
当我设置Build Configuration成Debug时,打印效果图
当我设置Build Configuration成Release的,打印时效果图
当Run Test Profile Analyze Archive的时候,都可以根据需要设置Debug和Release两个模式运行;
所以我们完全可以用一个宏指令来设置是否打印调试信息。
0 0
- [调试相关]预编译文件中宏定义打印日志
- [调试相关]预编译文件中宏定义打印日志
- 添加预编译文件 ,定义宏
- IOS 预编译文件 常定义的几个宏定义
- xcode使用pch预编译文件来禁止nslog打印
- prefixHeader预编译文件里的定义不好使
- 将调试相关日志打印到文件中
- 宏定义日志打印
- Unity3D 预编译相关宏定义
- 调试信息的宏定义:能够打印出文件名、函数、行数、日志,方便调试
- aspnet_compiler预编译文件
- C++预编译文件
- 添加预编译文件
- Android 定义全局LOG打印日志,并显示调用者相关信息
- Tomcat调试及日志打印
- C++日志调试打印接口
- 真机调试打印日志
- Android Log 日志调试(打印日志)
- 23种设计模式,UML图
- 《iOS Run Loop 线下分享》的简单总结
- Android Studio JNI 的静动态注册开发以及C/C++ JNIEnv的理解
- 浅析busybox内置的ftpd服务程序如何配置
- iOS 多线程编程<二、GCD基本用法>
- [调试相关]预编译文件中宏定义打印日志
- Linux查找最近修改的文件
- MySql学习笔记-增删改查操作
- firefox插件(plugin)开发概述
- 第五周项目二 建立链栈算法库
- python 使用MethodType绑定方法到类
- 分析ClassLoader
- 52. N-Queens II
- bootstrap-datetimepicker日期插件使用