Android应用如何反馈Crash报告

为什么需要反馈Crash报告?

做Android应用程序,要尽量避免程序Crash的发生。虽然说零Crash是程序员追逐的最终目标,但是现实的情况是,程序员只能尽量的减少Crash的发生,而几乎不可能完全杜绝Crash。也许,你认为你的应用的健壮性已经近乎完美,轻松的经受住了测试部门魔鬼般的考验,但是当你的应用发布到市场,面对百万甚至千万级别的用户的时候,可能就没有那么幸运了。

基于以上原因,一般的应用程序,都要有一个Crash反馈的机制。程序员可以根据反馈的结果,对当前的版本的代码进行改进,使发布的下一个版本更加稳定。

如何反馈?

先来看如何捕获Crash的发生。

Java中有一个接口,UncaughtExceptionHandler,先看描述。


static interface


Thread.UncaughtExceptionHandler 
          当 Thread 因未捕获的异常而突然终止时,调用处理程序的接口。

再来看Thread类中的一个方法。


static void


setDefaultUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh) 
          设置当线程由于未捕获到异常而突然终止,并且没有为该线程定义其他处理程序时所调用的默认处理程序。

看了这些API,就知道我们需要实现这样一个接口,然后在程序的主线程中设置处理程序。

看下面的接口实现。

package com.arui.framework.android.exception;  
  
   
  
import java.lang.Thread.UncaughtExceptionHandler;  
  
import android.content.Context;  
  
   
  
/** 
 
 * Default exception handler for all activities. 
 
 *  
 
 * @author http://blog.csdn.net/arui319 
 
 * @version 2011/12/01 
 
 *  
 
 */  
  
public class DefaultExceptionHandler implements UncaughtExceptionHandler {  
  
   
  
    private Context act = null;  
  
   
  
    public DefaultExceptionHandler(Context act) {  
  
       this.act = act;  
  
    }  
  
   
  
    @Override  
  
    public void uncaughtException(Thread thread, Throwable ex) {  
  
   
  
       // 收集异常信息 并且发送到服务器  
  
       sendCrashReport(ex);  
  
   
  
       // 等待半秒  
  
       try {  
  
           Thread.sleep(500);  
  
       } catch (InterruptedException e) {  
  
           //  
  
       }  
  
         
  
       // 处理异常  
  
       handleException();  
  
   
  
    }  
  
   
  
    private void sendCrashReport(Throwable ex) {  
  
   
  
       StringBuffer exceptionStr = new StringBuffer();  
  
       exceptionStr.append(ex.getMessage());  
  
   
  
       StackTraceElement[] elements = ex.getStackTrace();  
  
       for (int i = 0; i < elements.length; i++) {  
  
           exceptionStr.append(elements[i].toString());  
  
       }  
  
   
  
       //TODO   
  
       //发送收集到的Crash信息到服务器  
  
    }  
  
   
  
    private void handleException() {  
  
       //TODO   
  
       //这里可以对异常进行处理。  
  
       //比如提示用户程序崩溃了。  
  
       //比如记录重要的信息,尝试恢复现场。  
  
       //或者干脆记录重要的信息后,直接杀死程序。  
  
    }  
  
   
  
}

在主Activity的onCreate(Bundle savedInstanceState)方法中增加如下代码。

Thread.setDefaultUncaughtExceptionHandler(new DefaultExceptionHandler(  
  
       this.getApplicationContext()));

如何发送到服务器?

这个不同的项目组会有不同的方式,具体不在这里讨论了。需要提醒的是,除了把异常的具体信息发送给服务器外,至少还需要发送版本信息,这样程序员才可以判断服务器上的异常信息是哪个版本出现的。除了版本信息,可能还需要手机的SDK版本,屏幕分辨率,手机型号等等信息,有了这些信息,可以更全面的了解异常信息。

更多说明。

只需要在主Activity中设置一次异常处理类即可,不需要在所有的Acitivity都进行设置。

个人感觉Crash发生后,恢复现场继续运行的意义不大。Crash以后,程序的运行情况已经是不可预知的了,用一个错误,去弥补另外一个错误,本身就会导致更多的错误。建议还是尽量避免Crash的发生更合理。

---------------------------------------------------------------------------

GL(arui319) 

http://blog.csdn.net/arui319

<本文可以转载,但是请保留以上作者信息。谢谢。>

---------------------------------------------------------------------------

时间: 2025-01-06 23:37:56

Android应用如何反馈Crash报告的相关文章

Android dump .so 文件crash log

众所周知,在android系统上,有时候我们遇到so文件的crash只能打log,但是很多时候并不知道crash在什么地方,幸运的是crash后,一般可以产生一个.dmp文件. 我们可以根据这个文件来得到更为详细的statck trace. 主要用的就是google提供的一些方法,命令太复杂,很容易出错,所以我写了一个python脚本,简化步骤. 详情可以参考 https://code.google.com/p/google-breakpad/wiki/LinuxStarterGuide #!

Android 调试native的crash和anr

1. 在trace中找到对应的库,例如 liba.so和对应的地址信息 2. 使用addr2line 查看 addr2line 地址 -e liba.so -f 或者 arm-eabi-addr2line 3. 如果addr2line打不出具体的函数就用objdump objdump -s -d liba.so > xxx.txt 或者arm-eabi-objdump 然后再分析具体的原因. Android 调试native的crash和anr

2017-2018-2 20165336 实验四《Android开发基础》实验报告

20165336 实验四 Android程序设计 一.实验报告封面 课程:Java程序设计 班级:1653班 姓名:康志强 学号:20165336 指导教师:娄嘉鹏 实验日期:2018年5月14日 实验时间:13:45 - 15:25 实验序号:实验四 实验名称:Android程序设计 二.实验要求 1.没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim编辑器> 课程 2.完成实验.撰写实验报告,实验报告以博客方式发表在博客园,注意实验报告重点是运行结果,遇到

2017-2018-2 20165331 实验四《Android开发基础》实验报告

实验四 <Android开发基础> 实验报告封面 课程:Java程序设计 班级:1653 姓名:胡麟 学号:20165331 成绩: 指导教师:娄嘉鹏 实验日期:2018.5.14 实验密级: 预习程度: 实验时间:15:35 - 17:50 仪器组次:31 必修/选修: 实验序号:4 实验名称:Android开发基础 实验目的与要求:①完成云班课中的检查点,也可以先完成实验报告,直接提交.注意不能只有截图,要有知识点,原理,遇到的问题和解决过程等说明.实验报告中一个检查点要有多张截图. ②发

2017-2018-2 20165215 实验四《Android开发基础》实验报告

2017-2018-2 20165215 实验四<Android开发基础>实验报告 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:张家佳 学号:20165215 指导教师:娄嘉鹏 实验日期:2018年5月14日 实验时间:15:35 - 18:00 实验序号:四 实验名称: Andorid程序设计 二.实验目的与要求: 完成实验.撰写实验报告,注意实验报告重点是运行结果,遇到的问题以及分析 实验报告中统计自己的PSP(Personal Software Process)时间

2018-2019-2 20175105王鑫浩《Java程序设计》实验四 《Android开发基础》实验报告

实验四 <Android开发基础> 实验报告封面 课程:Java程序设计 班级:1751班 姓名:王鑫浩 学号:20175105 指导教师:王鑫浩 实验日期:2019年4月29日 实验时间:--- 实验序号:实验三 实验名称:敏捷开发与XP实践 实验要求 参考Android开发简易教程 完成云班课中的检查点,也可以先完成实验报告,直接提交.注意不能只有截图,要有知识点,原理,遇到的问题和解决过程等说明.实验报告中一个检查点要有多张截图. 发表实验报告博客,标题"学期(如2018-20

2018-2019-2 20175126谢文航 实验四《Android开发基础》实验报告

一.实验封面 课程:Java程序设计 班级:1751 班 姓名:谢文航 学号:20175126 指导教师:娄嘉鹏 实验日期:2019年5月15日 实验时间:--- 实验序号:实验四 实验名称:Android开发基础 实验内容: 参考Android开发简易教程 完成云班课中的检查点,也可以先完成实验报告,直接提交.注意不能只有截图,要有知识点,原理,遇到的问题和解决过程等说明.实验报告中一个检查点要有多张截图. 发表实验报告博客,标题“学期(如2018-2019-2) 学号(如20175300)

android开发之应用Crash自动抓取Log_自动保存崩溃日志到本地

http://blog.csdn.net/jason0539/article/details/45602655 应用发生crash之后要查看log,判断问题出在什么地方,可是一旦应用发布出去,就要想办法把用户的崩溃日志拿到分析. 所以要在发生crash之后抓取log,然后上传到服务器,方便开发者查看,现在都有很多第三方做这方面的服务,这里说下如何自己来实现. 其实原理很简单,应用出现异常后,会由默认的异常处理器来处理异常, 我们要做的就是把这个任务接管过来,自己处理异常,包括收集日志,保存到本地

2017-2018-2 20165236 实验四《Android开发基础》实验报告

一.实验报告封面 课程:Java程序设计       班级:1652班       姓名:郭金涛       学号:20165236 指导教师:娄嘉鹏                              实验日期:2018年5月14日 实验时间:15:35 - 17:15                    实验序号:四 实验名称:Android开发基础 二.实验内容 1.没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim编辑器> 课程: 2.完成实验