亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS Crash常規跟蹤方法及Bugly集成運用詳細介紹

2020-07-26 03:07:35
字體:
來源:轉載
供稿:網友

iOS Crash常規跟蹤方法及Bugly集成運用

當app出現崩潰, 研發階段一般可以通過以下方式來跟蹤crash信息

#1.模擬器運行, 查看xcode錯誤日志

#2.真機調試, 查看xcode錯誤日志

#3.真機運行, 查看device系統日志

 下面舉例說明, 先寫一段會Crash的代碼crashdemo:

- (void)viewDidLoad {  [super viewDidLoad];  // Do any additional setup after loading the view, typically from a nib.  [self performSelector:@selector(print) withObject:nil afterDelay:5];}- (void)print {  NSArray *array = @[];  NSLog(@"%@", array[1]);}

Demo#1.模擬器運行, 查看xcode錯誤日志

程序執行后會立即崩潰, 打開xcode系統日志可以看到以下錯誤信息

2016-10-29 12:13:29.015 CrashDemo[37842:7436441] *** Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArray0 objectAtIndex:]: index 1 beyond bounds for empty NSArray'*** First throw call stack:(  0  CoreFoundation           0x00b7ba84 __exceptionPreprocess + 180  1  libobjc.A.dylib           0x00642e02 objc_exception_throw + 50  2  CoreFoundation           0x00b22390 __CFArrayGetTypeID_block_invoke + 0  3  CoreFoundation           0x00ac07f8 -[NSArray objectAtIndexedSubscript:] + 40  4  CrashDemo              0x000877b7 -[ViewController print] + 87  5  Foundation             0x00250d71 __NSFireDelayedPerform + 442  6  CoreFoundation           0x00acd576 __CFRUNLOOP_IS_CALLING_OUT_TO_A_TIMER_CALLBACK_FUNCTION__ + 22  7  CoreFoundation           0x00accf72 __CFRunLoopDoTimer + 1250  8  CoreFoundation           0x00a8b25a __CFRunLoopRun + 2202  9  CoreFoundation           0x00a8a706 CFRunLoopRunSpecific + 470  10 CoreFoundation           0x00a8a51b CFRunLoopRunInMode + 123  11 GraphicsServices          0x041e4664 GSEventRunModal + 192  12 GraphicsServices          0x041e44a1 GSEventRun + 104  13 UIKit                0x00f0c1eb UIApplicationMain + 160  14 CrashDemo              0x00087bba main + 138  15 libdyld.dylib            0x03189a21 start + 1)libc++abi.dylib: terminating with uncaught exception of type NSException(lldb) 

通過xcode日志可以看到是數組訪問越界, 發生越界的方式名為print

針對這個demo我們當然很清楚是剛才列的array[1]發生越界, 但對于一個完整的程序如何查看是在哪個地方發生越界的呢?

這個時候我們可以利用xcode的Show the breakpoint navigator功能, 點加號選擇add exception breakpoint

這個時候我們在執行程序, xcode執行會自動停在要發生crash的代碼段

Demo#2.真機調試, 查看xcode錯誤日志
如果有添加exeception point, 程序會自動停到打印array[1]那一行. 如果沒有添加則程序會crash, xcode會出現以下錯誤日志

2016-10-29 12:15:53.561 CrashDemo[1062:316582] *** Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArray0 objectAtIndex:]: index 1 beyond bounds for empty NSArray'*** First throw call stack:(0x211b398b 0x2094ee17 0x211433e7 0xc5a3b 0x219d1ad5 0x211765ff 0x21176231 0x2117407d 0x210c32e9 0x210c30d5 0x226b3ac9 0x257880b9 0xc5c99 0x20d6b873)libc++abi.dylib: terminating with uncaught exception of type NSException(lldb) 

通過錯誤信息我們只能看到是有發生數組訪問越界, 如果有添加exeception breakpoint則會自動停在發生error的代碼行.

 Demo#3. 真機運行, 查看device系統日志

xcode停止運行這個crashdemo, 選擇xcode window - devices, 選擇手機 - view device logs

然后在手機上運行crashdemo, 在device logs中按時間排序查看最新的log就能看到crashdemo的crash log

Incident Identifier: 9A4C52F0-B0D7-42C9-A7CB-D4D3321D00D5CrashReporter Key:  90f4d3621773443794fa73f506fd6bdef49fc269Hardware Model:   iPhone4,1Process:       CrashDemo [1074]Path:        /private/var/containers/Bundle/Application/1307034E-9C2B-451F-ACD9-04C97DEC047B/CrashDemo.app/CrashDemoIdentifier:     PEGA.CrashDemoVersion:       1 (1.0)Code Type:      ARM (Native)Parent Process:   launchd [1]Date/Time:      2016-10-29 12:21:49.49 +0800Launch Time:     2016-10-29 12:21:43.43 +0800OS Version:     iOS 9.3.1 (13E238)Report Version:   104Exception Type: EXC_CRASH (SIGABRT)Exception Codes: 0x0000000000000000, 0x0000000000000000Exception Note: EXC_CORPSE_NOTIFYTriggered by Thread: 0Filtered syslog:None foundLast Exception Backtrace:0  CoreFoundation          0x211b3986 __exceptionPreprocess + 1221  libobjc.A.dylib          0x2094ee12 objc_exception_throw + 342  CoreFoundation          0x211433e2 -[__NSArray0 objectAtIndex:] + 1103  CrashDemo             0x000e6a36 0xe0000 + 271904  Foundation            0x219d1ad0 __NSFireDelayedPerform + 4645  CoreFoundation          0x211765fa 

這些在開發階段都能很簡便的實現, 但是當app發布出去后用戶發生crash呢? 一般用戶只能反饋在做什么的時候發生crash

然后我們在去做嘗試是否能遇到, 不過這樣效率不高而且一般很難復現到用戶的crash

Bugly的出現解決的這個問題

Bugly SDK在當程序崩潰時, 會自動將錯誤信息發送到服務器方便開發人員查看分析

那么如何使用Bugly?

首先先到https://bugly.qq.com/v2/注冊賬號, 并注冊app下載SDK包

將Bugly.framework拖拽到工程中, 記得勾選copy if needed.

然后添加libz.tbd / libstdc++.tbd / Security.framework / SystemConfiguration.framework到工程中

delegate.m中注冊

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {     [Bugly startWithAppId:@"此處替換為你的AppId"];     return YES;  }

這樣當程序發生崩潰時, 崩潰信息會自動發送到服務器登錄你的bugly賬號就能查看到了

 

 感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美高清视频在线| 久久伊人精品天天| 欧美激情在线有限公司| 亚洲精品在线观看www| 国产精品欧美在线| 国产成人精品在线视频| 国产精品久久久久久久久久三级| 中文国产成人精品久久一| 美女999久久久精品视频| 亚洲国产精品大全| 亚洲国产古装精品网站| 亚洲视频日韩精品| 国产精品成av人在线视午夜片| 日韩成人av在线播放| 日韩精品日韩在线观看| 国产精品视频一区二区高潮| 久久久久在线观看| 欧美日韩亚洲视频| 欧美精品性视频| 97av在线视频免费播放| 美乳少妇欧美精品| 成人欧美在线观看| 欧美高清理论片| 亚洲男人的天堂在线播放| 欧美亚洲视频在线看网址| 欧美日韩免费一区| 最新的欧美黄色| 国产一区二区三区视频在线观看| 性欧美暴力猛交69hd| 久久久亚洲福利精品午夜| 国产一区欧美二区三区| 色香阁99久久精品久久久| 亚洲天堂av在线免费| 欧美成人在线免费视频| xvideos亚洲人网站| 92看片淫黄大片欧美看国产片| 久久久99久久精品女同性| 日韩在线视频观看| 57pao成人永久免费视频| 国产日产欧美精品| 久久精品国产欧美亚洲人人爽| 国内外成人免费激情在线视频网站| 欧美日韩亚洲一区二| 狠狠色狠狠色综合日日五| 亚洲欧美在线x视频| 欧美性色视频在线| 久久久在线免费观看| 亚洲欧洲在线播放| 欧美激情乱人伦一区| 45www国产精品网站| 高清一区二区三区四区五区| 26uuu另类亚洲欧美日本一| 日韩免费在线播放| 亚洲天堂男人的天堂| 国产综合久久久久久| 国产欧美精品在线| 91亚洲精品一区| 国模视频一区二区| 色综久久综合桃花网| 国产激情综合五月久久| 91高清在线免费观看| 日韩免费在线观看视频| 国产精品视频不卡| 亚洲国产婷婷香蕉久久久久久| 欧美性猛交xxxx乱大交| 亚洲第一区中文99精品| 久久久免费观看| 国产成人在线视频| 成人国产精品久久久| 亚洲影院色无极综合| 欧美黑人狂野猛交老妇| 日韩国产高清污视频在线观看| 97久久久免费福利网址| 亚洲精品电影久久久| 亚洲天堂免费视频| 国产成人一区二区三区| 亚洲色图13p| 91chinesevideo永久地址| 欧美一区二区三区免费视| 亚洲激情电影中文字幕| 亚洲最大的av网站| 日韩免费在线免费观看| 国产一区欧美二区三区| 国产亚洲精品va在线观看| 欧美激情videoshd| 国产999精品| 久久这里有精品| 欧美性猛交xxxx免费看久久久| 91超碰caoporn97人人| 中文字幕不卡在线视频极品| 久久久天堂国产精品女人| 一区三区二区视频| 精品国产乱码久久久久酒店| 国产亚洲精品久久| 日韩亚洲一区二区| 亚洲**2019国产| 精品国产依人香蕉在线精品| 亚洲精品久久久久| 精品久久久久人成| 在线观看国产精品91| 欧美激情久久久久| 亚洲精品成人免费| 91日本在线视频| 日韩免费电影在线观看| 久久天天躁狠狠躁夜夜躁| 欧美国产日韩免费| 亚洲free嫩bbb| 欧美另类69精品久久久久9999| 欧美劲爆第一页| 日本不卡视频在线播放| 日韩精品免费在线视频观看| 国产精品视频中文字幕91| 亚洲天堂免费在线| 亚洲91精品在线| 国产伊人精品在线| 91精品国产91久久久久久最新| 欧美亚洲另类制服自拍| 国产欧美日韩专区发布| 亚洲精品永久免费| 久久久成人av| 久久久av亚洲男天堂| 91免费在线视频网站| 国产成人啪精品视频免费网| 97在线免费观看视频| 亚洲视频国产视频| 国产精品观看在线亚洲人成网| 亚洲国产日韩欧美在线图片| 亚洲一区二区免费| 日韩欧美中文第一页| 久久久久久久久久av| 欧美国产在线电影| 国产精品嫩草影院一区二区| 91精品国产成人| 在线精品国产成人综合| 成人中文字幕在线观看| 欧美自拍视频在线| 国产福利精品视频| 青青久久av北条麻妃海外网| 亚洲精品少妇网址| 国产成人啪精品视频免费网| 在线播放日韩av| 亚洲精选在线观看| 福利一区视频在线观看| 亚洲成av人片在线观看香蕉| 国产成人精品电影久久久| 亚洲美女激情视频| 最近2019中文免费高清视频观看www99| 国产成人精品日本亚洲专区61| 亚洲午夜女主播在线直播| 欧美色videos| 国产一区二区av| 69**夜色精品国产69乱| 精品久久久久久久久久久久久久| 性欧美xxxx交| 亚洲免费伊人电影在线观看av| 久久国产加勒比精品无码| 日韩精品久久久久久久玫瑰园| 91亚洲一区精品| 亚洲精品乱码久久久久久按摩观| 欧美在线视频一二三| 98午夜经典影视| 日韩精品久久久久久久玫瑰园| 国产精品久久久久久亚洲调教| 日韩一级裸体免费视频|