Android CrashHandler编写自己的异常捕获的方法

 更新时间:2017年12月11日 09:08:46   作者:danfengw  
这篇文章主要介绍了Android CrashHandler编写自己的异常捕获的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

平时写代码,我们可能会抛出各种异常,这些异常有些是我们测试过程中发现进行解决的,但是也有一些异常是我们未知的,不论是代码的逻辑问题还是Android本身底层的一些bug,我们都需要及时了解并进行解决。当用户在使用app出现崩溃现象时我们需要知道是什么原因,并将原因记录下来上到服务器,这样以后我们就可以知道具体是什么原因了 

CrashHandler类

用于记录crash原因保存到sd卡中。

public class CrashHandler implements Thread.UncaughtExceptionHandler {
  private static final String TAG = "CrashHandler";
  private static final boolean DEBUG = true;
  //文件路径
  private static final String PATH = Environment.getExternalStorageDirectory().getPath() +File.separator+ "crash";
  private static final String FILE_NAME = "crash";
  private static final String FILE_NAME_SUFEIX = ".trace";
  private static Thread.UncaughtExceptionHandler mDefaultCrashHandler;
  private static CrashHandler mCrashHandler = new CrashHandler();
  private Context mContext;

  private CrashHandler() {
  }

  public static CrashHandler getInstance() {
    return mCrashHandler;
  }

  public void init(Context context) {
    mDefaultCrashHandler = Thread.getDefaultUncaughtExceptionHandler();
    Thread.setDefaultUncaughtExceptionHandler(this);
    mContext = context.getApplicationContext();
  }

  @Override
  public void uncaughtException(Thread thread, Throwable ex) {
    try {
      //将文件写入sd卡
      writeToSDcard(ex);
      //写入后在这里可以进行上传操作
    } catch (IOException e) {
      e.printStackTrace();
    } catch (PackageManager.NameNotFoundException e) {
      e.printStackTrace();
    }
    ex.printStackTrace();
    //如果系统提供了默认异常处理就交给系统进行处理,否则自己进行处理。
    if (mDefaultCrashHandler != null) {
      mDefaultCrashHandler.uncaughtException(thread, ex);
    } else {
      Process.killProcess(Process.myPid());
    }
  }

  //将异常写入文件
  private void writeToSDcard(Throwable ex) throws IOException, PackageManager.NameNotFoundException {
    //如果没有SD卡,直接返回
    if (!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
      return;
    }
    File filedir = new File(PATH);
    if (!filedir.exists()) {
      filedir.mkdirs();
    }
    long currenttime = System.currentTimeMillis();
    String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date(currenttime));

    File exfile = new File(PATH +File.separator+FILE_NAME+time + FILE_NAME_SUFEIX);
    PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter(exfile)));
    Log.e("错误日志文件路径",""+exfile.getAbsolutePath());
    pw.println(time);
    PackageManager pm = mContext.getPackageManager();
    PackageInfo pi = pm.getPackageInfo(mContext.getPackageName(), PackageManager.GET_ACTIVITIES);
    //当前版本号
    pw.println("App Version:" + pi.versionName + "_" + pi.versionCode);
    //当前系统
    pw.println("OS version:" + Build.VERSION.RELEASE + "_" + Build.VERSION.SDK_INT);
    //制造商
    pw.println("Vendor:" + Build.MANUFACTURER);
    //手机型号
    pw.println("Model:" + Build.MODEL);
    //CPU架构
    pw.println("CPU ABI:" + Build.CPU_ABI);

    ex.printStackTrace(pw);
    pw.close();

  }


}

调用

public class BaseApplication extends Application {
  @Override
  public void onCreate() {
    super.onCreate();
    CrashHandler crashHandler=CrashHandler.getInstance();
    crashHandler.init(this);
  }
}

测试

 mButton.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View view) {
        throw new RuntimeException("抛出一个异常");
      }
    });

最后记得添加文件权限,并调用BaseApplication

这里写图片描述 

这里写图片描述

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 安卓Android Context类实例详解

    安卓Android Context类实例详解

    在开发Android的过程中,总是能遇见Context类或者它的实例.Context类的实例经常被用来提供“应用程序”的引用,下面举例说明Contex类实例详解
    2016-07-07
  • Android搜索结果显示高亮实例(有数据滑动底部自动刷新)

    Android搜索结果显示高亮实例(有数据滑动底部自动刷新)

    本篇文章主要介绍了Android搜索结果显示高亮实例(有数据滑动底部自动刷新),非常具有实用价值,需要的朋友可以参考下
    2017-04-04
  • Android WebView与JS交互全面详解(小结)

    Android WebView与JS交互全面详解(小结)

    本篇文章主要介绍了Android WebView与JS交互全面详解(小结),实现了Android客户端与Web网页交互,具有一定的参考价值,有兴趣的可以了解一下
    2017-11-11
  • Flutter实现用视频背景的登录页的示例代码

    Flutter实现用视频背景的登录页的示例代码

    这篇文章主要介绍了Flutter实现用视频背景的登录页的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • Android实现截屏功能

    Android实现截屏功能

    这篇文章主要为大家详细介绍了Android实现截屏功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • Android编程绘制抛物线的方法示例

    Android编程绘制抛物线的方法示例

    这篇文章主要介绍了Android编程绘制抛物线的方法,涉及Android图形绘制与数学运算相关操作技巧,需要的朋友可以参考下
    2017-06-06
  • Android自定义实现罗盘视图详解

    Android自定义实现罗盘视图详解

    在开发Android应用时,自定义视图是一个非常重要的技能,本文将介绍如何创建一个自定义的罗盘视图,感兴趣的小伙伴可以跟随小编一起学习一下
    2025-02-02
  • Android新布局方式ConstraintLayout快速入门教程

    Android新布局方式ConstraintLayout快速入门教程

    谷歌在2016年的IO大会上推出的一种新的布局方式—-ConstraintLayout,这局是一种约束型的布局方式,下面这篇文章主要给大家介绍了Android中新布局方式ConstraintLayout的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-05-05
  • android读取raw文件示例

    android读取raw文件示例

    这篇文章主要介绍了android读取raw文件示例,需要的朋友可以参考下
    2014-02-02
  • listview Button始终放在底部示例

    listview Button始终放在底部示例

    android实现底部布局往往使用RelativeLayout的布局方式,以下的例子就是实现三层布局的底部布局的功能,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07

最新评论