Android测试之logcat日志

本文详细介绍了日志文件的概念及其在系统调试中的作用,深入解析了Android系统的日志缓冲区机制,包括Radio、System、Event和Main四种类型的日志缓冲区。同时,文章还提供了logcat命令的使用方法,帮助开发者快速定位程序崩溃和ANR问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

什么是日志文件

日志是从各个软件和系统的一些缓冲区中记录下来的,提供记录、查看系统调试信息的功能,可以通过logcat来查看。

缓冲区

缓冲区是环形的、首尾相连,用于缓存固定数据大小的日志信息,开发者选项中有一个叫“日志记录器缓冲区大小”,默认为256k,通常写满时会删除最旧日志为新日志保留空间。
android log输出量巨大,特别是通信系统log,因此android把log输出到不同的缓冲区中,目前定义了四个log缓冲区:
·Radio——通信系统的log
·System——系统组件的log
·Event——event模块的log
·Main——java层的log
缓冲区主要给系统组件使用,一般的应用不需要关心,应用的log都输出到main缓冲区中,所以默认log输出(不指定缓冲区的情况下)是输出System+Main缓冲区的log。

logcat

logcat命令格式

PC端:adb logcat [option] ... [filter-spec] ...
shell下:logcat [option] ... [filter-spec] ...

日志分析

如果出现程序崩溃或者ANR,在日志中搜索“CRASH”或者“ANR”即可,从而定位到出现问题的代码行信息,常见的crash错误如下:

关键字crash原因
java.lang.NullPointerException空指针异常
java.lang.ArrayIndexOutOfBoundsException数组溢出
java.langClassNotFoundException类不存在
java.lang.ArithmeticException数学运算异常
java.lang.IllegaArgumentException方法参数异常
java.io.FileNotFoundException文件未找到
java.lang.NumberFormatException数值转化异常
java.lang.StackOverFlowError堆栈异常
java.lang.OutOfMemeryError内存溢出错误
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值