国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

iOS中控制NSLog輸出時機詳解

2020-07-26 02:36:27
字體:
來源:轉載
供稿:網友
-(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,即可只保留登錄模塊的日志了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鸡泽县| 高密市| 萝北县| 呼图壁县| 萨迦县| 晋江市| 沙田区| 石屏县| 刚察县| 景泰县| 余干县| 澳门| 枣庄市| 时尚| 泰兴市| 新巴尔虎右旗| 西畴县| 姚安县| 商丘市| 蚌埠市| 怀仁县| 江安县| 和林格尔县| 含山县| 凯里市| 高邑县| 衡阳市| 独山县| 延川县| 正镶白旗| 曲水县| 宝兴县| 义乌市| 安吉县| 屏南县| 昆山市| 河北区| 韶关市| 石河子市| 泗洪县| 稷山县|