iOS中 加强日志输出 开发技术总结
對于那些做后端開發(fā)的工程師來說,看LOG解Bug應(yīng)該是理所當(dāng)然的事,但我接觸到的移動(dòng)應(yīng)用開發(fā)的工程師里面,很多人并沒有這個(gè)意識,查Bug時(shí)總是一遍一遍的試圖重現(xiàn),試圖調(diào)試,特別是對一些不太容易重現(xiàn)的Bug經(jīng)常焦頭爛額。而且iOS的異常機(jī)制比較復(fù)雜,Objective-C的語言駕馭也需要一定的功力,做出來的應(yīng)用有時(shí)候挺容易產(chǎn)生崩潰閃退。一遍一遍的用XCode取應(yīng)用崩潰記錄、解析符號,通常不勝其煩,有時(shí)還對著解析出來的調(diào)用棧發(fā)呆,因?yàn)槌绦虍?dāng)時(shí)的內(nèi)部狀態(tài)常常難以看明白,只能去猜測。
對于真機(jī),日志沒法保存,不好分析問題。所以有必要將日志保存到應(yīng)用的Docunment目錄下,并設(shè)置成共享文件,這樣才能取出分析。
導(dǎo)入第三方:AFNetWorkinng
- (void)viewDidLoad {[super viewDidLoad];AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];[manager GET:@"http://mobile.ximalaya.com/m/category_tag_list?category=entertainment&device=iPhone&type=album" parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) {NSLog(@"%@", responseObject);} failure:^(AFHTTPRequestOperation *operation, NSError *error) {NSLog(@"%@", [error localizedDescription]);}];}給其寫一個(gè)類目:Foundation+Log.m
#import <Foundation/Foundation.h>@implementation NSDictionary (Log)//+ (void)load //{ // NSLog(@"11"); //}- (NSString *)descriptionWithLocale:(id)locale {NSMutableString *str = [NSMutableString string];[str appendString:@"{\n"];[self enumerateKeysAndObjectsUsingBlock:^(id key, id obj, BOOL *stop) {[str appendFormat:@"\t%@ = %@, \n", key, obj];}];[str appendString:@"}"];// 刪除最后一個(gè),NSRange range = [str rangeOfString:@"," options:NSBackwardsSearch];[str deleteCharactersInRange:range];return str; }@end@implementation NSArray (Log)- (NSString *)descriptionWithLocale:(id)locale {NSMutableString *str = [NSMutableString string];[str appendString:@"[\n"];[self enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {[str appendFormat:@"\t\t%@,\n", obj];}];[str appendString:@"]"];// 刪除最后一個(gè),NSRange range = [str rangeOfString:@"," options:NSBackwardsSearch];[str deleteCharactersInRange:range];return str; }@end
小技巧:iOS - 將控制臺Log日志轉(zhuǎn)為輸出為文本文件
1.在AppDelegate.m中創(chuàng)建函數(shù)實(shí)現(xiàn)以下代碼塊: - (void)redirectNSlogToDocumentFolder {NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);NSString *documentDirectory = [paths objectAtIndex:0];NSString *fileName = [NSString stringWithFormat:@"MrNSLog.txt"];// 注意不是NSData!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); } 2.在didFinishLaunchingWithOptions中調(diào)用 : [self redirectNSlogToDocumentFolder]; 最后配置共享文件夾:
在應(yīng)用程序的Info.plist文件中添加UIFileSharingEnabled鍵,并將鍵值設(shè)置為YES。將您希望共享的文件放在應(yīng)用程序的?Documents目錄。一旦設(shè)備插入到用戶計(jì)算機(jī),iTunes9.1就會在選中設(shè)備的Apps標(biāo)簽中顯示一個(gè)File Sharing區(qū)域。此后,用戶就可以向該目錄添加文件或者將文件移動(dòng)到桌面計(jì)算機(jī)中。如果應(yīng)用程序支持文件共享,當(dāng)文件添加到Documents目錄后,應(yīng)用程序應(yīng)該能夠識別并做出適當(dāng)響應(yīng)。例如說,應(yīng)用程序可以將新文件的內(nèi)容顯示界面上。請不要向用戶展現(xiàn)目錄的文件列表并詢問他們希望對文件執(zhí)行什么操作。
每日更新關(guān)注:http://weibo.com/hanjunqiang? 新浪微博
<pheiti sc="" light'"="">
總結(jié)
以上是生活随笔為你收集整理的iOS中 加强日志输出 开发技术总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: django实现长链接
- 下一篇: js平滑滚动到顶部,底部,指定地方