找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2942|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

Android Force Close和ANR等異常處理方法

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:140343 發(fā)表于 2016-9-25 11:03 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
對android應(yīng)用而言最常出現(xiàn)的異常是Force close和ANR(Application is not response).

對于這兩類錯(cuò)誤而言,應(yīng)用是可以進(jìn)行相關(guān)處理的。

一 Forceclose這類問題主要通過Thread.UncaughtExceptionHandler這個(gè)類來捕獲異常。通過實(shí)現(xiàn)類里面的方法uncaughtException來實(shí)現(xiàn)應(yīng)用在捕獲到異常后進(jìn)行相關(guān)的處理。一般這里處理基本放在應(yīng)用的Application類中。為了方便大家進(jìn)行相關(guān)處理,我這里寫了個(gè)類,大家直接在Application回調(diào)即可。


  1. new ExceptionHandler(mContext).setFCListener(new ExceptionHandler.FCListener() {
  2.             
  3.             @Override
  4.             public void onFCDispose(Throwable paramThrowable) {
  5.                 Log.d(TAG, onFCListerner enter!!!);
  6.                 new Thread(){
  7.                     public void run(){
  8.                         Looper.prepare();
  9.                         Toast.makeText(mContext, APP is Force Close do what you want!, Toast.LENGTH_LONG).show();
  10.                         Looper.loop();
  11.                     }
  12.                 }.start();
  13.             }
  14.         });
復(fù)制代碼



同樣的對于ANR問題,應(yīng)用也可以做相關(guān)處理。對ANR,我們可以這樣處理。通過一個(gè)看門狗來實(shí)時(shí)的檢測主線程,一旦主線程發(fā)生阻塞,則通知Application 做相關(guān)處理。

主要方法是在線程中每隔一段時(shí)間(Activity一般是5S,廣播一般是10S),向主線程發(fā)送一個(gè)messager,使計(jì)數(shù)器加1,如果到點(diǎn)沒有加1,則表明主線程阻塞。


  1. @Override
  2.     public void run() {
  3.         setName(|ANR-WatchDog|);

  4.         int lastTick;
  5.         while (!isInterrupted()) {
  6.             lastTick = mTick;
  7.             mUIHandler.post(tickerRunnable);
  8.             try {
  9.                 Thread.sleep(mTimeoutInterval);
  10.             }
  11.             catch (InterruptedException e) {
  12.                 mInterruptionListener.onInterrupted(e);
  13.                 return ;
  14.             }

  15.             // If the main thread has not handled _ticker, it is blocked. ANR.
  16.             if (mTick == lastTick) {
  17.                 ANRError error;
  18.                 if (mNamePrefix != null)
  19.                     error = ANRError.New(mNamePrefix, mLogThreadsWithoutStackTrace);
  20.                 else
  21.                     error = ANRError.NewMainOnly();
  22.                 mAnrListener.onAppNotResponding(error);
  23.                 return ;
  24.             }
  25.         }
  26.     }
復(fù)制代碼
  1. private final Runnable tickerRunnable = new Runnable() {
  2.        @Override public void run() {
  3.            mTick = (mTick + 1) % 10;
  4.        }
  5.    };
復(fù)制代碼



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表