Android 日志写入不成功,Android将app的崩溃日志写入到文件中

获取App的崩溃信息

将以下代码放到Application的onCreate()中

private void logMessage{

//记录崩溃信息

final Thread.UncaughtExceptionHandler defaultHandler = Thread.getDefaultUncaughtExceptionHandler();

Thread.setDefaultUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {

@Override

public void uncaughtException(Thread thread, Throwable throwable) {

//获取崩溃时的UNIX时间戳

long timeMillis = System.currentTimeMillis();

//将时间戳转换成人类能看懂的格式,建立一个String拼接器

StringBuilder stringBuilder =new StringBuilder(new SimpleDateFormat("yyyy/MM/dd HH:mm:ss").format(new Date(timeMillis)));

stringBuilder.append(":\n");

//获取错误信息

stringBuilder.append(throwable.getMessage());

stringBuilder.append("\n");

//获取堆栈信息

StringWriter sw =new StringWriter();

PrintWriter pw =new PrintWriter(sw);

throwable.printStackTrace(pw);

stringBuilder.append(sw.toString());

//这就是完整的错误信息,保存到本地

String errorLog = stringBuilder.toString();

//将错误信息写入到文件中

FileUtils.setAppendFile(errorLog);

//最后处理这个崩溃,这里使用默认的处理方式让APP停止运行

defaultHandler.uncaughtException(thread, throwable);

}

});

}

写入到文件的工具类

import android.os.Environment;

import java.io.BufferedWriter;

import java.io.File;

import java.io.FileWriter;

import java.io.PrintWriter;

public class FileUtils {

private static final String appName = "yourAppName";

private static File file;

static {

file = new File(Environment.getExternalStorageDirectory(), appName);

if (!file.exists()) {

file.mkdirs();

}

file = new File(file, "log.txt");

}

/**

* 将文本追加写入到文件

*/

public static void setAppendFile(String value) {

FileWriter fw;

BufferedWriter bw;

PrintWriter printWriter = null;

try {

fw = new FileWriter(file, true);

bw = new BufferedWriter(fw);

printWriter = new PrintWriter(bw);

printWriter.println(value);

} catch (Exception e) {

e.printStackTrace();

} finally {

if (printWriter != null) {

printWriter.close();

}

}

}

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值