安卓如何获取APP的崩溃日志
2023-09-27 14:26:38 时间
参考:https://www.jianshu.com/p/644078912cfd?from=singlemessage
码字辛苦!转载请注明出处!
安卓APP一旦发生任何报错,就会停止运行,这是令许多开发者头疼的问题,
很多情况下,一些隐性BUG在测试部门通过,而在上架之后发生小面积崩溃,这时候的报错因为没有日志,导致BUG无从查起。
那么,只能通过用户反馈消耗大量的人力和时间去复现它吗?
![](http://upload-images.jianshu.io/upload_images/13223390-30cad2c0bb008350.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/142/format/webp)
其实只要在Application中插入一小段代码,就可以把完整的错误日志全部捕捉出来:
//记录崩溃信息
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();
//最后如何处理这个崩溃,这里使用默认的处理方式让APP停止运行
defaultHandler.uncaughtException(thread, throwable);
}
});
各位有自我修养的工程师们还不快get√起来~
相关文章
- 安卓逆向_22( 一 ) --- Xposed【 Android Studio + Xposed 实现简单的 hook 】
- 安卓逆向_19( 一 ) --- APK保护策略【APP打开就崩溃 之 霸哥apk过签名校验】
- 安卓逆向_13 --- AndroidStudio + Smalidea 动态调试 smali 代码【APK可调试】、gradle 配置
- 安卓入门基础(九)-对应用结构进行分析
- 我的Android前生今世之缘-学习经验-安卓入门教程(六)
- 安卓开发中Theme.AppCompat.Light的解决方法
- 安卓APT技术讲解(上)-实现安卓组件化的解耦
- 安卓代码中设置fontFamily中的样式
- js监测设备类型【安卓,ios,苹果微信,电脑pc】
- Mac—Scrcpy在Macbook上实现同屏/多屏协同操作安卓手机界面(支持 Win、Mac、Linux)
- 一种恶意程序专门攻击安卓
- 安卓开发笔记(三十一):shape标签下子类根结点的具体使用
- 安卓开发笔记(十九):异步消息处理机制实现更新软件UI