Android 捕获错误日志 UncaughtExceptionHandler

        Android系统的“程序异常退出”,给应用的用户体验造成不良影响。为了捕获应用运行时异常并给出友好提示,便可继承UncaughtExceptionHandler类来处理。通过Thread.setDefaultUncaughtExceptionHandler()方法将异常处理类设置到线程上即可。

/**
 * UncaughtExceptionHandler:线程未捕获异常控制器是用来处理未捕获异常的。 如果程序出现了未捕获异常默认情况下则会出现强行关闭对话框
 * 实现该接口并注册为程序中的默认未捕获异常处理 这样当未捕获异常发生时,就可以做些异常处理操作 例如:收集异常信息,发送错误报告 等。
 * UncaughtException处理类,当程序发生Uncaught异常的时候,由该类来接管程序,并记录发送错误报告. 
*
* 使用的时候只需要在Application中调用一下,create()函数即可 * * 创建时间 2014-7-2 */ public class CrashHandler implements UncaughtExceptionHandler { private final Context mContext; // log文件的后缀名 private static final String FILE_NAME_SUFFIX = ".log"; private static CrashHandler sInstance = null; private CrashHandler(Context cxt) { // 将当前实例设为系统默认的异常处理器 Thread.setDefaultUncaughtExceptionHandler(this); // 获取Context,方便内部使用 mContext = cxt.getApplicationContext(); } public synchronized static CrashHandler create(Context cxt) { if (sInstance == null) { sInstance = new CrashHandler(cxt); } return sInstance; } /** * 这个是最关键的函数,当程序中有未被捕获的异常,系统将会自动调用#uncaughtException方法 * thread为出现未捕获异常的线程,ex为未捕获的异常,有了这个ex,我们就可以得到异常信息。 */ @Override public void uncaughtException(Thread thread, Throwable ex) { try { // 导出异常信息到SD卡中 saveToSDCard(ex); } catch (Exception e) { } finally { // ex.printStackTrace();// 调试时打印日志信息 System.exit(0); } } private void saveToSDCard(Throwable ex) throws Exception { File file = FileUtils.getSaveFile("KJFrame", mContext.getPackageName() + FILE_NAME_SUFFIX); boolean append = false; if (System.currentTimeMillis() - file.lastModified() > 5000) { append = true; } PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter( file, append))); // 导出发生异常的时间 pw.println(SystemTool.getDataTime("yyyy-MM-dd-HH-mm-ss")); // 导出手机信息 dumpPhoneInfo(pw); pw.println(); // 导出异常的调用栈信息 ex.printStackTrace(pw); pw.println(); pw.close(); } private void dumpPhoneInfo(PrintWriter pw) throws NameNotFoundException { // 应用的版本名称和版本号 PackageManager pm = mContext.getPackageManager(); PackageInfo pi = pm.getPackageInfo(mContext.getPackageName(), PackageManager.GET_ACTIVITIES); pw.print("App Version: "); pw.print(pi.versionName); pw.print('_'); pw.println(pi.versionCode); pw.println(); // android版本号 pw.print("OS Version: "); pw.print(Build.VERSION.RELEASE); pw.print("_"); pw.println(Build.VERSION.SDK_INT); pw.println(); // 手机制造商 pw.print("Vendor: "); pw.println(Build.MANUFACTURER); pw.println(); // 手机型号 pw.print("Model: "); pw.println(Build.MODEL); pw.println(); // cpu架构 pw.print("CPU ABI: "); pw.println(Build.CPU_ABI); pw.println(); } }
在使用的时候只需要在程序的Application文件当中调用create()函数即可

CrashHandler.create(this);


你可能感兴趣的:(Android)