Android实现APP奔溃日志记录保存

public class CrashHandler implements java.lang.Thread.UncaughtExceptionHandler {
    private java.lang.Thread.UncaughtExceptionHandler defaultUncaughtExceptionHandler;

    public void init() {
        defaultUncaughtExceptionHandler = java.lang.Thread.getDefaultUncaughtExceptionHandler();
        java.lang.Thread.setDefaultUncaughtExceptionHandler(this);
    }

    @Override
    public void uncaughtException(Thread t, Throwable e) {
        java.lang.String externalStorageDirectoryPath = android.os.Environment.getExternalStorageDirectory().getAbsolutePath();
        java.text.DateFormat dateFormatForDate = new java.text.SimpleDateFormat("yyyy-MM-dd", java.util.Locale.getDefault());
        java.util.Date date = new java.util.Date();
        java.lang.String path = externalStorageDirectoryPath  + java.io.File.separator + "crash-" + dateFormatForDate.format(date) + ".log";
        java.lang.StringBuilder stringBuilder = new java.lang.StringBuilder();
        java.text.DateFormat dateFormatForDateTime = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss", java.util.Locale.getDefault());
        java.lang.String currentTime = dateFormatForDateTime.format(date);
        stringBuilder.append("CrashTime:").append(currentTime).append("\r\n");
        java.io.StringWriter stringWriter = new java.io.StringWriter();
        java.io.PrintWriter printWriter = new java.io.PrintWriter(stringWriter);
        e.printStackTrace(printWriter);
        java.lang.String stackTrace = stringWriter.toString();
        stringBuilder.append(stackTrace);
        try {
            java.io.File logFile = new java.io.File(path);
            java.io.FileWriter fileWriter = new java.io.FileWriter(logFile, true);
            fileWriter.write(stringBuilder.toString());
            fileWriter.close();
        } catch (java.io.IOException ioException) {
            ioException.printStackTrace();
        }
        if (defaultUncaughtExceptionHandler != null) {
            defaultUncaughtExceptionHandler.uncaughtException(t, e);
        } else {
            android.os.Process.killProcess(android.os.Process.myPid());
        }
    }
}

然后在自定义Application类的onCreate方法初始化即可

@Override
public void onCreate() {
    super.onCreate();
    CrashHandler crashHandler = new CrashHandler();
    crashHandler.init();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值