中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

iOS中捕獲日志與異常示例詳解

前言

創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司一直秉承“誠(chéng)信做人,踏實(shí)做事”的原則,不欺瞞客戶(hù),是我們最起碼的底線! 以服務(wù)為基礎(chǔ),以質(zhì)量求生存,以技術(shù)求發(fā)展,成交一個(gè)客戶(hù)多一個(gè)朋友!專(zhuān)注中小微企業(yè)官網(wǎng)定制,成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作,塑造企業(yè)網(wǎng)絡(luò)形象打造互聯(lián)網(wǎng)企業(yè)效應(yīng)。

在平時(shí)自己調(diào)試的時(shí)候,可以直接連接電腦,直接在窗口中查看結(jié)果。但是在測(cè)試人員測(cè)試,或者灰度測(cè)試的時(shí)候,怎么才能拿到日志呢?最先想到的肯定是輸出到本地文件,然后在需要的時(shí)候進(jìn)行上傳。

分享一段之前找到的方法,下面的代碼提供了兩個(gè)主要功能:

     – 把日志輸出到文件中

     – 捕捉異常信息

【解析都寫(xiě)在注釋中了】

示例代碼

- (void)redirectNSLogToDocumentFolder
{
//如果已經(jīng)連接X(jué)code調(diào)試則不輸出到文件
//該函數(shù)用于檢測(cè)輸出 (STDOUT_FILENO) 是否重定向 是個(gè) Linux 程序方法
if(isatty(STDOUT_FILENO)) {
return;
}

// 判斷 當(dāng)前是否在 模擬器環(huán)境 下 在模擬器不保存到文件中
UIDevice *device = [UIDevice currentDevice];
if([[device model] hasSuffix:@"Simulator"]){
return;
}

//將NSlog打印信息保存到Document目錄下的Log文件夾下
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *logDirectory = [[paths objectAtIndex:0] stringByAppendingPathComponent:@"Log"];

NSFileManager *fileManager = [NSFileManager defaultManager];
BOOL fileExists = [fileManager fileExistsAtPath:logDirectory];
if (!fileExists) {
[fileManager createDirectoryAtPath:logDirectory withIntermediateDirectories:YES attributes:nil error:nil];
}

NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setLocale:[[NSLocale alloc] initWithLocaleIdentifier:@"zh_CN"]];
[formatter setDateFormat:@"yyyy-MM-dd HH:mm:ss"]; //每次啟動(dòng)后都保存一個(gè)新的日志文件中
NSString *dateStr = [formatter stringFromDate:[NSDate date]];
NSString *logFilePath = [logDirectory stringByAppendingFormat:@"/%@.log",dateStr];

// 將log輸入到文件
freopen([logFilePath cStringUsingEncoding:NSUTF8StringEncoding], "a+", stdout);
freopen([logFilePath cStringUsingEncoding:NSUTF8StringEncoding], "a+", stderr);

//未捕獲的Objective-C異常日志
NSSetUncaughtExceptionHandler (&UncaughtExceptionHandler);
}

之前看的時(shí)候,對(duì) NSSetUncaughtExceptionHandler(&UncaughtExceptionHandler) 這個(gè)用法一知半解,去翻了一下源碼,這個(gè)方法是在 Foundation 中。

api 中的定義是Changes the top-level error handler ,Sets the top-level error-handling function where you can perform last-minute logging before the program terminates. 通過(guò)替換掉最高級(jí)別的 handle 方法,可以在程序終止之前可以獲取到崩潰信息,并執(zhí)行相應(yīng)的操作,比如保存本地,或者上報(bào)。

方法調(diào)用為:

void NSSetUncaughtExceptionHandler(NSUncaughtExceptionHandler *);

傳入的是一個(gè) NSUncaughtExceptionHandler 的指針。

typedef void NSUncaughtExceptionHandler(NSException *exception);

意思就是需要一個(gè) 返回 void 并且參數(shù)為 NSException *exception 的函數(shù)指針。

你想要,那我就給你!

所以下面有個(gè) C 語(yǔ)言的函數(shù),你看這個(gè)寫(xiě)法和 OC 的聲明也不一樣。

void UncaughtExceptionHandler(NSException* exception)
{
NSString* name = [ exception name ];
NSString* reason = [ exception reason ];
NSArray* symbols = [ exception callStackSymbols ]; // 異常發(fā)生時(shí)的調(diào)用棧
NSMutableString* strSymbols = [ [ NSMutableString alloc ] init ]; //將調(diào)用棧拼成輸出日志的字符串
for ( NSString* item in symbols )
{
[ strSymbols appendString: item ];
[ strSymbols appendString: @"\r\n" ];
}

//將crash日志保存到Document目錄下的Log文件夾下
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *logDirectory = [[paths objectAtIndex:0] stringByAppendingPathComponent:@"Log"];

NSFileManager *fileManager = [NSFileManager defaultManager];
if (![fileManager fileExistsAtPath:logDirectory]) {
[fileManager createDirectoryAtPath:logDirectory withIntermediateDirectories:YES attributes:nil error:nil];
}

NSString *logFilePath = [logDirectory stringByAppendingPathComponent:@"UncaughtException.log"];
NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setLocale:[[NSLocale alloc] initWithLocaleIdentifier:@"zh_CN"]];
[formatter setDateFormat:@"yyyy-MM-dd HH:mm:ss"];
NSString *dateStr = [formatter stringFromDate:[NSDate date]];

NSString *crashString = [NSString stringWithFormat:@"<- %@ ->[ Uncaught Exception ]\r\nName: %@, Reason: %@\r\n[ Fe Symbols Start ]\r\n%@[ Fe Symbols End ]\r\n\r\n", dateStr, name, reason, strSymbols];
//把錯(cuò)誤日志寫(xiě)到文件中
if (![fileManager fileExistsAtPath:logFilePath]) {
[crashString writeToFile:logFilePath atomically:YES encoding:NSUTF8StringEncoding error:nil];
}else{
NSFileHandle *outFile = [NSFileHandle fileHandleForWritingAtPath:logFilePath];
[outFile seekToEndOfFile];
[outFile writeData:[crashString dataUsingEncoding:NSUTF8StringEncoding]];
[outFile closeFile];
}

//把錯(cuò)誤日志發(fā)送到郵箱
// NSString *urlStr = [NSString stringWithFormat:@"mailto://XXXXX@126.com?subject=bug報(bào)告&body=感謝您的配合!<br><br><br>錯(cuò)誤詳情:<br>%@",crashString ];
// NSURL *url = [NSURL URLWithString:[urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
// [[UIApplication sharedApplication] openURL:url];
}

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)各位iOS開(kāi)發(fā)者們能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。

當(dāng)前題目:iOS中捕獲日志與異常示例詳解
網(wǎng)頁(yè)鏈接:http://www.rwnh.cn/article38/pgeopp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司外貿(mào)網(wǎng)站建設(shè)、定制開(kāi)發(fā)小程序開(kāi)發(fā)、服務(wù)器托管、ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(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)

成都app開(kāi)發(fā)公司
临沧市| 随州市| 曲阳县| 白朗县| 建水县| 贵阳市| 广饶县| 松江区| 阜阳市| 平利县| 镇江市| 双辽市| 冀州市| 建昌县| 平凉市| 鸡泽县| 迭部县| 合水县| 呼伦贝尔市| 定日县| 山阳县| 格尔木市| 寻乌县| 古丈县| 哈密市| 德令哈市| 九寨沟县| 虎林市| 林西县| 上蔡县| 班戈县| 姚安县| 福州市| 东乌珠穆沁旗| 崇左市| 松潘县| 湛江市| 楚雄市| 高雄县| 舟山市| 高密市|