崩潰日志收集框架 - java crash收集流程分析

本篇文章考赛,針對(duì)java crash處理進(jìn)行分析,因?yàn)轫?xiàng)目的原因代碼選擇:Android 5.0今豆。瞄了眼嫌拣,高版本代碼差不多,沒啥太大變化呆躲。

一异逐、Java異常

java crash日志捕獲針對(duì)的是UnChecked Exception中沒有被catch住的RuntimeException。

二插掂、Java異常捕獲

1)自定義Handler 實(shí)現(xiàn)UncaughtExceptionHandler接口
2)Thread.setDefaultUncaughtExceptionHandler(UncaughtExceptionHandler eh)設(shè)置自定義Handler
3)java crash回調(diào)UncaughtExceptionHandler 的uncaughtException方法灰瞻,實(shí)現(xiàn)奔潰信息收集,上報(bào)辅甥。

三酝润、原理解析

這里主要就搞明白三個(gè)問題:

  • 默認(rèn)的UncaughtExceptionHandler何時(shí)設(shè)置?
  • 應(yīng)用發(fā)生java crash系統(tǒng)層都做了哪些工作璃弄?
  • uncaughtException何時(shí)回調(diào)要销?

下面一個(gè)個(gè)來分析:

1)默認(rèn)的UncaughtExceptionHandler何時(shí)設(shè)置?

進(jìn)程啟動(dòng)流程zygoteInit方法中:

android-5.0.0_r7/frameworks/base/core/java/com/android/internal/os/RuntimeInit.java

public static final void zygoteInit(int targetSdkVersion, String[] argv, ClassLoader classLoader)
        throws ZygoteInit.MethodAndArgsCaller {
...
   commonInit();
...
}

private static final void commonInit() {
   /* set default handler; this applies to all threads in the VM */
   Thread.setDefaultUncaughtExceptionHandler(new UncaughtHandler());
...
}

很明顯夏块,這是應(yīng)用進(jìn)程創(chuàng)建過程中設(shè)置的默認(rèn)UncaughtExceptionHandler疏咐。

2)應(yīng)用發(fā)生java crash系統(tǒng)層都做了哪些工作?

這里接著上面繼續(xù)看脐供, Thread.setDefaultUncaughtExceptionHandler(new UncaughtHandler());
UncaughtHandler的實(shí)現(xiàn):

private static class UncaughtHandler implements Thread.UncaughtExceptionHandler {
    public void uncaughtException(Thread t, Throwable e) {
     …
            // Bring up crash dialog, wait for it to be dismissed
           ActivityManagerNative.getDefault().handleApplicationCrash(
                    mApplicationObject, new ApplicationErrorReport.CrashInfo(e));
     …
       finally {
            // Try everything to make sure this process goes away.
           Process.killProcess(Process.myPid());
           System.exit(10);
       }
    }
}

接下來整個(gè)流程總結(jié)為一個(gè)時(shí)序圖:

簡單總結(jié)系統(tǒng)層工作內(nèi)容:

  • 將進(jìn)程crash信息輸出到/data/system/dropbox中凳鬓。
  • 針對(duì)進(jìn)程,調(diào)整activity及其任務(wù)棧患民。
  • 彈crash對(duì)話框缩举。
  • Process.killprocess 走binder死亡回調(diào),清理進(jìn)程及其四大組件。

3)uncaughtException何時(shí)回調(diào)仅孩?

Java進(jìn)程是運(yùn)行在虛擬機(jī)中的托猩,當(dāng)出現(xiàn)運(yùn)行時(shí)異常時(shí),虛擬機(jī)會(huì)調(diào)用:

android-5.0.0_r7/art/runtime/thread.cc

void Thread::HandleUncaughtExceptions(ScopedObjectAccess& soa) {
 ...
  // Call the handler.
  tlsPtr_.jni_env->CallVoidMethod(handler.get(),
      WellKnownClasses::java_lang_Thread$UncaughtExceptionHandler_uncaughtException,
      peer.get(), exception.get());
  // If the handler threw, clear that exception too.
  tlsPtr_.jni_env->ExceptionClear();
}

JNI回調(diào)到j(luò)ava的uncaughtException辽慕。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
禁止轉(zhuǎn)載京腥,如需轉(zhuǎn)載請(qǐng)通過簡信或評(píng)論聯(lián)系作者。
  • 序言:七十年代末溅蛉,一起剝皮案震驚了整個(gè)濱河市公浪,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌船侧,老刑警劉巖欠气,帶你破解...
    沈念sama閱讀 221,548評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異镜撩,居然都是意外死亡预柒,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門袁梗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宜鸯,“玉大人,你說我怎么就攤上這事遮怜×苄洌” “怎么了?”我有些...
    開封第一講書人閱讀 167,990評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵锯梁,是天一觀的道長即碗。 經(jīng)常有香客問我,道長涝桅,這世上最難降的妖魔是什么拜姿? 我笑而不...
    開封第一講書人閱讀 59,618評(píng)論 1 296
  • 正文 為了忘掉前任烙样,我火速辦了婚禮冯遂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘谒获。我一直安慰自己蛤肌,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,618評(píng)論 6 397
  • 文/花漫 我一把揭開白布批狱。 她就那樣靜靜地躺著裸准,像睡著了一般。 火紅的嫁衣襯著肌膚如雪赔硫。 梳的紋絲不亂的頭發(fā)上炒俱,一...
    開封第一講書人閱讀 52,246評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼权悟。 笑死砸王,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的峦阁。 我是一名探鬼主播谦铃,決...
    沈念sama閱讀 40,819評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼榔昔!你這毒婦竟也來了驹闰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,725評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤撒会,失蹤者是張志新(化名)和其女友劉穎嘹朗,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體茧彤,經(jīng)...
    沈念sama閱讀 46,268評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡骡显,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,356評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了曾掂。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片惫谤。...
    茶點(diǎn)故事閱讀 40,488評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖珠洗,靈堂內(nèi)的尸體忽然破棺而出溜歪,到底是詐尸還是另有隱情,我是刑警寧澤许蓖,帶...
    沈念sama閱讀 36,181評(píng)論 5 350
  • 正文 年R本政府宣布蝴猪,位于F島的核電站,受9級(jí)特大地震影響膊爪,放射性物質(zhì)發(fā)生泄漏自阱。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,862評(píng)論 3 333
  • 文/蒙蒙 一米酬、第九天 我趴在偏房一處隱蔽的房頂上張望沛豌。 院中可真熱鬧,春花似錦赃额、人聲如沸加派。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,331評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽白热。三九已至锡垄,卻和暖如春驱闷,著一層夾襖步出監(jiān)牢的瞬間逆害,已是汗流浹背往果。 一陣腳步聲響...
    開封第一講書人閱讀 33,445評(píng)論 1 272
  • 我被黑心中介騙來泰國打工筑公, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人孽水。 一個(gè)月前我還...
    沈念sama閱讀 48,897評(píng)論 3 376
  • 正文 我出身青樓檬输,卻偏偏與公主長得像,于是被迫代替她去往敵國和親匈棘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子丧慈,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,500評(píng)論 2 359