欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS中控制NSLog輸出時機詳解

 更新時間:2017年12月03日 09:04:29   作者:和平老三不帶V  
本文給大家介紹的是iOS開發(fā)中關(guān)于nslog的輸出時機的相關(guān)內(nèi)容,非常簡單實用,有需要的小伙伴可以參考下
-(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];
  // 先刪除已經(jīng)存在的文件
  NSFileManager *defaultManager = [NSFileManager defaultManager];
  [defaultManager removeItemAtPath:logFilePath error:nil];
  
  // 將log輸入到文件
  freopen([logFilePath cStringUsingEncoding:NSASCIIStringEncoding], "a+", stdout);
  freopen([logFilePath cStringUsingEncoding:NSASCIIStringEncoding], "a+", stderr);
}

這個方法主要是調(diào)用 freopen 這個方法來寫入, 其中 stdout 和 stderr 囊括了 iOS 大部分的異常輸出。

2. 根據(jù) Bool 值控制 log 輸出

用戶在使用 app 遇到各種各樣的問題,當(dāng)自己以及測試團隊不好定位原因的時候,能將用戶把關(guān)鍵點的 log 發(fā)送過來是最好的分析方法了。但是如何將 app 運行過程中的 log 截取一部分保存呢?像開關(guān)一樣能夠控制 log 的讀寫呢?通過閱讀 MQTTLog 源碼發(fā)現(xiàn)獲得的靈感。

首先對 NSLog 進行下宏替換,項目中統(tǒng)一使用 SLOG 來進行輸出

#define SLOG(fmt, ...) if (reportLoggerIsOpen) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__)
從宏定義可以看出,reportLoggerIsOpen 是控制 Log 輸出的開關(guān),對于reportLoggerIsOpen的定義,在 h 文件中先 extern 聲明這個變量,然后再 m 文件中去實現(xiàn)。

.h 文件

#import <Foundation/Foundation.h>

extern BOOL reportLoggerIsOpen;
.m 文件
BOOL reportLoggerIsOpen = NO;

+ (void)setLogOpen:(BOOL)open {
  reportLoggerIsOpen = open;
}

通過 setLogOpen 這個方法,就能夠收放自如的控制日志寫入了。比如你需要抓取登錄模塊的日志,那么就在登錄前傳入 true,登錄完畢后,傳入 false,即可只保留登錄模塊的日志了。

相關(guān)文章

  • Objective-C的緩存框架EGOCache在iOS App開發(fā)中的使用

    Objective-C的緩存框架EGOCache在iOS App開發(fā)中的使用

    這篇文章主要介紹了Objective-C的緩存框架EGOCache在iOS App開發(fā)中的使用,重點講解了EGOCache對緩存過期時間的檢測及處理,需要的朋友可以參考下
    2016-05-05
  • iOS頁面跳轉(zhuǎn)及數(shù)據(jù)傳遞(三種)

    iOS頁面跳轉(zhuǎn)及數(shù)據(jù)傳遞(三種)

    本文主要介紹了iOS頁面跳轉(zhuǎn)的三種方法及數(shù)據(jù)傳遞的方法。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • 源碼解析ios開發(fā)SDWebImage方法

    源碼解析ios開發(fā)SDWebImage方法

    這篇文章主要為大家介紹了源碼解析ios開發(fā)SDWebImage方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • iOS中的實時遠程配置全紀錄

    iOS中的實時遠程配置全紀錄

    這篇文章主要給大家介紹了關(guān)于iOS中實時遠程配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • iOS應(yīng)用開發(fā)中圖片的拉伸問題解決方案

    iOS應(yīng)用開發(fā)中圖片的拉伸問題解決方案

    這篇文章主要介紹了iOS應(yīng)用開發(fā)中圖片的拉伸問題解決方案,有時圖片的拉伸只需要拉伸中間部分而不拉伸兩端,這是本文所關(guān)注的問題,需要的朋友可以參考下
    2016-02-02
  • ios實現(xiàn)簡單隨便移動的AR功能

    ios實現(xiàn)簡單隨便移動的AR功能

    這篇文章主要為大家詳細介紹了ios實現(xiàn)簡單隨便走的AR功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • IOS開發(fā)用戶登錄注冊模塊所遇到的問題

    IOS開發(fā)用戶登錄注冊模塊所遇到的問題

    最近和另外一位同事負責(zé)公司登錄和用戶中心模塊的開發(fā)工作。通過本文給大家分享IOS開發(fā)用戶登錄注冊模塊所遇到的問題,感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • iOS使用 CABasicAnimation 實現(xiàn)簡單的跑馬燈(無cpu暴漲)

    iOS使用 CABasicAnimation 實現(xiàn)簡單的跑馬燈(無cpu暴漲)

    本篇文章主要介紹了iOS使用 CABasicAnimation 實現(xiàn)簡單的跑馬燈(無cpu暴漲),具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01
  • react-native中AsyncStorage實例詳解

    react-native中AsyncStorage實例詳解

    這篇文章主要介紹了react-native中AsyncStorage實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • 你應(yīng)該知道的tableViewCell行高計算處理

    你應(yīng)該知道的tableViewCell行高計算處理

    這篇文章主要給大家介紹了關(guān)于tableViewCell行高計算的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12

最新評論