iOS开发之NSLog打印控制

开发过程中,我们会在项目中添加很多日志以便调试,打包后这些日志并不需要,我们可以将这些日志屏蔽掉。

一、添加宏定义

#ifdef DEBUG
#define DLog(s,...) NSLog(@"%s LINE:%d < %@ >",__FUNCTION__, __LINE__, [NSString stringWithFormat:(s), ##__VA_ARGS__]);
#define DMethod() NSLog(@"%s", __func__);
#else
#define DLog(...);
#define DMethod();
#endif

在使用时直接使用Dlog就可以在release模式去掉日志

二、使用开关日志输出

添加日志输出管理方法

1. 首先在.h中添加方法

#pragma mark -- 日志方法
// 设置日志输出状态
+ (void)setLogEnable:(BOOL)enable;

// 获取日志输出状态
+ (BOOL)getLogEnable;

// 日志输出方法
+ (void)customLogWithFunction:(const char *)function lineNumber:(int)lineNumber formatString:(NSString *)formatString;

2. 在.m文件中,设置静态变量来存储日志输出状态值

// 默认值为NO
static BOOL kLogEnable = NO;

3. 实现类方法

#pragma mark -- 日志方法
// 设置日志输出状态
+ (void)setLogEnable:(BOOL)enable {
    kLogEnable = enable;
}

// 获取日志输出状态
+ (BOOL)getLogEnable {
    return kLogEnable;
}

// 日志输出方法
+ (void)customLogWithFunction:(const char *)function lineNumber:(int)lineNumber formatString:(NSString *)formatString {
    if ([self getLogEnable]) {
        // 开启了Log
        NSLog(@"%s[%d]%@", function, lineNumber, formatString);
    }
}

4. 添加宏定义

#define DLog(format,...)  [STATUtils customLogWithFunction:__FUNCTION__ lineNumber:__LINE__ formatString:[NSString stringWithFormat:format, ##__VA_ARGS__]]

使用宏定义打印就可以自己控制日志输出

5. 在使用时,实现控制方法

[Utils setLogEnable:YES];
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 重点掌握 3 类对象和方法 对象就是一个物体 类的独特存在就是一个实例,对实例进行操作叫做方法。方法可以应用于类或...
    Coder大雄阅读 1,291评论 0 2
  • 原文地址 在应用开发中为了给用户更好操作体验与精准信息的展示,往往会收集一些用户行为信息,比如应用中用户习惯的操作...
    DestinyFighter_阅读 9,469评论 0 30
  • 我看完博主Ale鎏白的小熊猫日常后,非常不信邪的尝试了一下。然后,变成了一只超肥的橘猫。想到国庆假已经放完,我就是...
    梁少闲阅读 444评论 4 7
  • 今日体验:听到拓客回来的家人,说挺不容易的,现在社会都抵触推销,想让一个陌生人相信也需要怎么去说,才能达成,做好准备。
    不将就_66ee阅读 84评论 0 0
  • 其实喜欢一个人, 最初一定是他或者他的某些行为打动了你。引起了情感的牵结,灵魂的交谈。 最近很喜欢一句词 天咫尺,...
    Carrieye阅读 284评论 0 0