Android異常處理最佳實踐
一個好的app 異常處理機制 我認為應該至少包含以下幾個功能:
1.能把錯誤信息上傳到服務器 讓開發(fā)者可以持續(xù)改進app
2.錯誤信息至少應該包含 是否在主進程 是否在主線程 等可以幫助程序員定位的信息
3.最好包含手機硬件及軟件信息。
4.主進程引發(fā)的異常 最好交由系統(tǒng)自己處理 也就是讓用戶可以感知到 那種(當然你也可以自己定義一套更有意思的感知系統(tǒng)對話框等,具體可參考各種有意思的404界面)
5.子進程引發(fā)的異常最好別讓用戶感知到。比如push之類的 這種 和用戶感知弱關聯(lián)的這種。最好發(fā)生異常就直接kill掉即可。不要再交給系統(tǒng)處理。
下面上代碼。
package com.example.administrator.exceptiontest; import android.app.ActivityManager; import android.app.Application; import android.content.Context; /** * Created by Administrator on 2015/12/9. */ public class BaseApplication extends Application { public static Context mContext; //默認的異常處理 public static Thread.UncaughtExceptionHandler defaultUncaughtExceptionHandler; @Override public void onCreate() { super.onCreate(); mContext = this; //先取得默認的異常處理handler defaultUncaughtExceptionHandler = Thread.getDefaultUncaughtExceptionHandler(); Thread.setDefaultUncaughtExceptionHandler(new BaseUncaughtExceptionHandler()); } }
package com.example.administrator.exceptiontest; import android.app.ActivityManager; import android.content.Context; import android.os.Looper; /** * Created by Administrator on 2015/12/9. */ public class Utils { /** * 判斷是否在主線程中執(zhí)行 如果是返回true 不是返回false */ public static boolean isInMainThread() { //注意這個地方 我們無法一定可以取得myLooper的值的 比如說 你的thread 沒有綁定消息循環(huán) //那你的mylooper就返回的一定是null了,只有綁定了以后才會返回相應的值 return Looper.myLooper() == Looper.getMainLooper(); } //判斷是否是主進程 如果是 就返回true 否則返回false public static boolean isMainProcess(Context context) { return context.getPackageName().equals(getProcessName(context)); } //取得進程名 public static String getProcessName(Context context) { String currentProcessName = ""; int pid = android.os.Process.myPid(); ActivityManager manager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE); for (ActivityManager.RunningAppProcessInfo processInfo : manager.getRunningAppProcesses()) { if (processInfo.pid == pid) { currentProcessName = processInfo.processName; break; } } return currentProcessName; } }
package com.example.administrator.exceptiontest; import java.io.PrintWriter; import java.io.StringWriter; import java.io.Writer; /** * Created by Administrator on 2015/12/9. */ public class BaseUncaughtExceptionHandler implements Thread.UncaughtExceptionHandler { @Override public void uncaughtException(Thread thread, Throwable ex) { Writer resultWriter = new StringWriter(); PrintWriter printWriter = new PrintWriter(resultWriter); ex.printStackTrace(printWriter); StringBuffer sb = new StringBuffer(); sb.append("是否在主線程中發(fā)生異常" + Utils.isInMainThread() + "\n"); sb.append("是否在主進程中發(fā)生異常" + Utils.isMainProcess(BaseApplication.mContext) + "\n"); String errorReport = sb.toString() + resultWriter.toString(); //這個地方最好把收集到的錯誤信息日志 上傳至服務器 便于開發(fā)者定位修改問題。 //如果是主進程發(fā)生了異常 那還是交給系統(tǒng)自己默認的異常處理來做。讓用戶感知到,否則用戶啥都不知道 體驗并不好 //你當然也可以自己定義特殊的錯誤提示 比如一些有意思的dialog什么的 if (Utils.isMainProcess(BaseApplication.mContext)) { BaseApplication.defaultUncaughtExceptionHandler.uncaughtException(thread, ex); } else { //如果是子進程發(fā)生異常 不要給提示 直接殺掉子進程最好 別讓用戶感知到 android.os.Process.killProcess(android.os.Process.myPid()); } } }
以上就是本文的全部內(nèi)容,希望對大家學習Android軟件編程有所幫助。
相關文章
Android自定義ViewGroup實現(xiàn)可滾動的橫向布局(2)
這篇文章主要介紹了Android自定義ViewGroup實現(xiàn)可滾動的橫向布局,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12Android Walker登錄記住密碼頁面功能實現(xiàn)
這篇文章主要為大家詳細介紹了Android Walker登錄記住密碼頁面功能的實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05Android利用廣播接收器實現(xiàn)自動填充短信驗證碼
這篇文章主要為大家詳細介紹了Android利用廣播接收器實現(xiàn)自動填充短信驗證碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12android listview 水平滾動和垂直滾動的小例子
android listview 水平滾動和垂直滾動的小例子,需要的朋友可以參考一下2013-05-05Android Compose實現(xiàn)伸縮ToolBar的思路詳解
這篇文章主要介紹了Android Compose之伸縮ToolBar的實現(xiàn),本文給大家分享主要實現(xiàn)思路及實現(xiàn)過程,通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2021-10-10