編輯:關於Android編程
一個好的app 異常處理機制 我認為應該至少包含以下幾個功能:
1.能把錯誤信息上傳到服務器 讓開發者可以持續改進app
2.錯誤信息至少應該包含 是否在主進程 是否在主線程 等可以幫助程序員定位的信息
3.最好包含手機硬件及軟件信息。
4.主進程引發的異常 最好交由系統自己處理 也就是讓用戶可以感知到 那種(當然你也可以自己定義一套更有意思的感知系統對話框等,具體可參考各種有意思的404界面)
5.子進程引發的異常最好別讓用戶感知到。比如push之類的 這種 和用戶感知弱關聯的這種。最好發生異常就直接kill掉即可。不要再交給系統處理。
下面上代碼。
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 {
/**
* 判斷是否在主線程中執行 如果是返回true 不是返回false
*/
public static boolean isInMainThread() {
//注意這個地方 我們無法一定可以取得myLooper的值的 比如說 你的thread 沒有綁定消息循環
//那你的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("是否在主線程中發生異常" + Utils.isInMainThread() + "\n");
sb.append("是否在主進程中發生異常" + Utils.isMainProcess(BaseApplication.mContext) + "\n");
String errorReport = sb.toString() + resultWriter.toString();
//這個地方最好把收集到的錯誤信息日志 上傳至服務器 便於開發者定位修改問題。
//如果是主進程發生了異常 那還是交給系統自己默認的異常處理來做。讓用戶感知到,否則用戶啥都不知道 體驗並不好
//你當然也可以自己定義特殊的錯誤提示 比如一些有意思的dialog什麼的
if (Utils.isMainProcess(BaseApplication.mContext)) {
BaseApplication.defaultUncaughtExceptionHandler.uncaughtException(thread, ex);
} else {
//如果是子進程發生異常 不要給提示 直接殺掉子進程最好 別讓用戶感知到
android.os.Process.killProcess(android.os.Process.myPid());
}
}
}
Android 新聞界面模擬ListView和ViewPager的應用
模擬新聞 APP 的界面1)寫 ListView 之前先寫布局: 這裡有兩種 Item 的布局:<?xml version=1.0 encodin
淘淘商城---8.7
昨天將框架整合完成,現在我主要實現昨天的需求,實現商品的列表查詢,這時要涉及到jsp和serveilet知識,不清楚的朋友可以趕緊去補充下知識。1、商品列表的實現1.1、
谷歌推出Android 響應式布局控件 FlexboxLayout -彈性盒子模型
今天github 排行榜上突然出現了 谷歌最新推出的Android 最新控件FlexboxLayout 。 FlexboxLayout究竟是什麼東西
Android5.1中surface和CpuConsumer下生產者和消費者間的處理框架簡述
前沿: 如果對SurfaceFlinger架構的工作原理較為熟悉的話,本文閱讀起來會相對容易些。之所以撰寫本文是因為在閱讀Camera HAL3的實現過程中