安卓的错误捕捉与日志输出探讨

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 今天工作时对安卓的错误抛出进行了探究,同时对日志输出也看了一番,所以今天我们聊聊安卓在这个方面的写法。

正篇

首先,我们在需要对APP错误进行分析时,我们通常会在对应位置打印日志,但有时候有些位置由于异常而直接导致程序崩溃,这时候就需要我们抛出错误,捕捉异常,输出相应日志。

不规范的示例:

try {
    throw new FileNotFoundException();
} catch (Exception e) {
    e.fillInStackTrace();
    Log.e("There has a error, code = ", e.getMessage());
}

网络异常,图片无法展示
|


这里的 System.exit(0)是用于在异常获取并输出日志后退出程序。

而XLog是非常好用的日志输出工具,可同时在多个通道打印日志,如 Logcat、Console 和文件。

这里我们用到的是XLog的这个方法:

/**
 * Log a message and a throwable with level {@link LogLevel#ERROR}.
 *
 * @param msg the message to log
 * @param tr  the throwable to be log
 */
public static void e(String msg, Throwable tr) {
  assertInitialization();
  sLogger.e(msg, tr);
}

当然,这里附上最新的XLog包导入命令,在项目下app的build.gradle中加入下列这一行代码:

implementation 'com.elvishew:xlog:1.10.1'

网络异常,图片无法展示
|


即可使用XLog来输出日志,官方给出的介绍说这是一款轻量、美观强大、可扩展的 Android 和 Java 日志库。


网络异常,图片无法展示
|


从官方给出的图来看,的确非常清晰。 如果想使用可以看这个官方使用文档:xLog/README_ZH.md at master · elvishew/xLog · GitHub

小结

今天这篇是有感而发,希望可以总结平时收获,后面会单独开栏用来收集这些平时突然想记录的技术小栈,希望可以记得更扎实一些。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
8月前
|
存储 监控 iOS开发
iOS应用崩溃了,如何通过崩溃手机连接电脑查找日志方法
在iOS应用开发过程中,调试日志和奔溃日志是开发者必不可少的工具。当iOS手机崩溃时,我们可以连接电脑并使用Xcode Console等工具来查看日志。然而,这种方式可能不够方便,并且处理奔溃日志也相当繁琐。克魔助手的出现为开发者带来了极大的便利,本文将详细介绍其功能和使用方法。 克魔助手会提供两种日志,一种是实时的,一种的是崩溃的。(由于崩溃日志的环境很麻烦,目前只展示实时日志操作步骤)
|
Android开发 C语言
[笔记]安卓 使用breakpad定位崩溃问题
[笔记]安卓 使用breakpad定位崩溃问题
136 0
|
Android开发 iOS开发
判断手机端获取哪种类型的手机系统-安卓-ios
判断手机端获取哪种类型的手机系统-安卓-ios
|
iOS开发 MacOS Python
|
Android开发
安卓一个奇怪的LOG:ColorDrawable.setColor
安卓一个奇怪的LOG:ColorDrawable.setColor
90 0
|
存储 iOS开发
iOS崩溃排查技巧:symbolicatecrash符号化分析问题、导出和隐藏符号
iOS崩溃排查技巧:symbolicatecrash符号化分析问题、导出和隐藏符号
477 0
iOS崩溃排查技巧:symbolicatecrash符号化分析问题、导出和隐藏符号
|
Android开发
安卓日常开发记录-键盘的相关处理方式
点击EditText之外隐藏键盘的实现方式 重写事件分发dispatchTouchEvent,注意不要在onTouchEvent中操作,因为onTouchEvent并非任何情况下都会被调用。
1184 0
斑马标签打印机蛋疼的打印错误处理方法
斑马标签打印机蛋疼的打印错误处理方法 默认自动检测的纸张,打印预览的时候没有问题,但是打印出来的效果,就一小块,打印不全。这个蛋疼的问题,可能和操作系统有关系,win10打印的时候没有问题,win7就不行。
1389 0