91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在iOS中控制NSLog輸出時機

發布時間:2021-03-09 17:38:15 來源:億速云 閱讀:170 作者:Leah 欄目:移動開發

今天就跟大家聊聊有關怎么在iOS中控制NSLog輸出時機,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

-(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,即可只保留登錄模塊的日志了。

看完上述內容,你們對怎么在iOS中控制NSLog輸出時機有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

奉贤区| 田林县| 张家界市| 开原市| 淮北市| 连云港市| 郸城县| 台州市| 广德县| 徐州市| 静海县| 同仁县| 泾源县| 岳阳县| 富锦市| 乌恰县| 长汀县| 昂仁县| 小金县| 宁阳县| 枣阳市| 井研县| 和田市| 泽普县| 昌乐县| 会宁县| 广元市| 泗水县| 兰坪| 望城县| 进贤县| 通州区| 巴塘县| 克什克腾旗| 长岭县| 民丰县| 沂南县| 美姑县| 石嘴山市| 竹溪县| 安岳县|