欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

怎么在iOS中控制NSLog輸出時(shí)機(jī)-創(chuàng)新互聯(lián)

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

創(chuàng)新新互聯(lián),憑借十載的網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站經(jīng)驗(yàn),本著真心·誠(chéng)心服務(wù)的企業(yè)理念服務(wù)于成都中小企業(yè)設(shè)計(jì)網(wǎng)站有1000+案例。做網(wǎng)站建設(shè),選成都創(chuàng)新互聯(lián)
-(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);
}

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

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

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

首先對(duì) NSLog 進(jìn)行下宏替換,項(xiàng)目中統(tǒng)一使用 SLOG 來(lái)進(jìn)行輸出

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

.h 文件

#import <Foundation/Foundation.h>

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

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

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

看完上述內(nèi)容,你們對(duì)怎么在iOS中控制NSLog輸出時(shí)機(jī)有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝大家的支持。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.chinadenli.net,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

新聞標(biāo)題:怎么在iOS中控制NSLog輸出時(shí)機(jī)-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://www.chinadenli.net/article2/djdcoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開(kāi)發(fā)軟件開(kāi)發(fā)網(wǎng)站改版網(wǎng)站收錄網(wǎng)頁(yè)設(shè)計(jì)公司網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作