当前位置: 移动技术网 > IT编程>移动开发>IOS > iOS中控制NSLog输出时机详解

iOS中控制NSLog输出时机详解

2019年07月24日  | 移动技术网IT编程  | 我要评论

手机上youtube,淘宝刷钻石,青青岛社区胶南论坛

-(void)savedebuglog{
  nsarray *paths = nssearchpathfordirectoriesindomains(nsdocumentdirectory, nsuserdomainmask, yes);
  nsstring *documentdirectory = [paths objectatindex:0];
  
  nsdateformatter *dateformatter = [[nsdateformatter alloc] init];
  [dateformatter setdateformat:@"yyyy_mm_dd_hh_mm_ss"];
  nsstring *currentdatestr = [dateformatter stringfromdate:[nsdate date]];
  nsstring *filename = [nsstring stringwithformat:@"testlog_%@.log",currentdatestr];
  
  nsstring *logfilepath = [documentdirectory stringbyappendingpathcomponent:filename];
  // 先删除已经存在的文件
  nsfilemanager *defaultmanager = [nsfilemanager defaultmanager];
  [defaultmanager removeitematpath:logfilepath error:nil];
  
  // 将log输入到文件
  freopen([logfilepath cstringusingencoding:nsasciistringencoding], "a+", stdout);
  freopen([logfilepath cstringusingencoding:nsasciistringencoding], "a+", stderr);
}

这个方法主要是调用 freopen 这个方法来写入, 其中 stdout 和 stderr 囊括了 ios 大部分的异常输出。

2. 根据 bool 值控制 log 输出

用户在使用 app 遇到各种各样的问题,当自己以及测试团队不好定位原因的时候,能将用户把关键点的 log 发送过来是最好的分析方法了。但是如何将 app 运行过程中的 log 截取一部分保存呢?像开关一样能够控制 log 的读写呢?通过阅读 mqttlog 源码发现获得的灵感。

首先对 nslog 进行下宏替换,项目中统一使用 slog 来进行输出

#define slog(fmt, ...) if (reportloggerisopen) nslog((@"%s [line %d] " fmt), __pretty_function__, __line__, ##__va_args__)
从宏定义可以看出,reportloggerisopen 是控制 log 输出的开关,对于reportloggerisopen的定义,在 h 文件中先 extern 声明这个变量,然后再 m 文件中去实现。

.h 文件

#import <foundation/foundation.h>

extern bool reportloggerisopen;
.m 文件
bool reportloggerisopen = no;

+ (void)setlogopen:(bool)open {
  reportloggerisopen = open;
}

通过 setlogopen 这个方法,就能够收放自如的控制日志写入了。比如你需要抓取登录模块的日志,那么就在登录前传入 true,登录完毕后,传入 false,即可只保留登录模块的日志了。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网