iOS自定义打印开关

前言

因为公司的SDK是以.a的静态库形式发出去的, 所有给其他人用的时候可能一些内部信息看不到, 导致调试起来很费劲.
参考了友盟的打印接口.
完整的实现如下:

实现

定位你要加接口的文件类, 然后添加如下代码

.h

#pragma mark - 自定义打印开关
/** 设置是否打印sdk的log信息, 默认NO(不打印log).
 @param value 设置为YES,SDK 会输出log信息可供调试参考. 除非特殊需要,否则发布产品时需改回NO.
 @return void.
 */
+ (void)setLogEnabled:(BOOL)yesOrNo;
+ (BOOL)logEnable;

.m

static BOOL HNX_Log_Switch = NO;

#pragma mark - 自定义打印开关
+ (void)setLogEnabled:(BOOL)value {
    HNX_Log_Switch = value;
}

+ (BOOL)logEnable {
    return HNX_Log_Switch;
}

//自定义打印
#define HNXLog(format, ...) {\
if ([你的类 logEnable]) {\
NSLog(@"[Ablecloud]: %s():%d " format, __func__, __LINE__, ##__VA_ARGS__);\
}\
}\

这个宏定义可以放在任务地方, 我是单独创建了一个header文件来存放, 你也可以放在.pch或者任意头文件中.

自定义打印默认是关闭, 你也可以通过改变HNX_Log_Switch的初始值来默认开启

使用

- (void)viewDidLoad {
    [super viewDidLoad];
    
    HNXLog(@"自定义打印1");
    HNXLog(@"自定义打印2");
    HNXLog(@"自定义打印3");
    //打开自定义打印开关
    [customLog setLogEnabled:YES];
    HNXLog(@"自定义打印4");
    HNXLog(@"自定义打印5");   
}

打印结果:

2016-07-19 11:08:31.525 CustomLogSwitch[17926:5409234] [HNX]: -[ViewController viewDidLoad]():27 自定义打印4
2016-07-19 11:08:31.526 CustomLogSwitch[17926:5409234] [HNX]: -[ViewController viewDidLoad]():28 自定义打印5

结尾

git上有一份代码,大家可以看一下 链接在这里

https://github.com/dfzr86/customLogSwitch

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,786评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,281评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,010评论 6 342
  • 08/13/2017 周日 丁酉年 闰六月二十二日】 √静√智√勇√仁√强√礼 - 小结 上午篮球课,。 - 明日...
    妈妈熊阅读 166评论 0 0
  • 天爱上了海,可是空气却把它们阻隔开了,它们无法相爱了,于是天哭了,泪水落在海里。即使不能相爱,天也要把灵魂寄托给海...
    萧远山阅读 733评论 0 2