Android developers
1、启用开发者选项(连续点击设备版本号
2、点击bug报告(不同系统稍有差异
3、选择所需bug报告类型,点击报告
4、通知栏会有完成提示,点击可分享
5、文件管理中可找到报告文件
“Extended controls”窗口中的 File a bug 功能:
1、点击模拟器面板中的 More 图标
2、在 Extended controls 窗口中选择 Bug report
此时系统会打开一个屏幕,您可以在其中查看 bug 报告详细信息,例如屏幕截图、AVD 配置信息和 bug 报告日志。您还可以输入一条包含重现步骤的消息,以便与报告一起保存。
3、等待 bug 报告完成收集,然后点击 Save Report
adb bugreport 路径
1、GooglePlay管理中心
2、build.gradle中添加Firebase崩溃报告功能
生成的报告文件默认命名为bugreport-BUILD_ID-DATE.zip
bugreport-BUILD_ID-DATE.txt
就是 bug 报告,包含系统服务 (dumpsys)、错误日志 (dumpstate) 和系统消息日志 (logcat) 的诊断输出,系统消息包括设备抛出错误时的堆栈轨迹,以及从所有应用中使用 Log 类写入的消息。
Android source
Android developer
logcat是一个命令行工具,用于转储系统消息日志,包括设备抛出错误时的堆栈轨迹,以及从所有应用中使用 Log 类写入的消息。
系统进程logd
维护的一组结构化环形缓冲区,缓冲区是固定由系统定义的。类型包含如下:日志缓冲区
adb shell logcat
,可简写为adb logcat
adb logcat --help
查询可用选项
每行记录以timestamp PID TID log-level
开头
以下优先级由低到高:
修改日志的输出格式,以显示特定的数据字段
adb logcat -v --help
android日志记录系统为日志消息保留了多个环形缓冲区,并非所有消息都会发送到默认的环形缓冲区
adb logcat -b
查看任意缓冲区
adb logcat -b
adb logcat -b
,查看多个缓冲区
Android developers
Application Not Responding,应用无响应
一定时间内一些事件未得到有效响应或响应时间过长,系统就会出现ANR,系统会终止该进程并将堆栈转储到/data/anr
Android中应用响应性由Activity管理器和窗口管理器系统服务监控。当Android检测到一下某一条件时,便会显示相应ANR:
Android应用通常完全在单线程中运行(默认为界面线程或主线程)。应用在界面线程汇总执行任何需要很长时间的操作都有可能触发ANR,因为应用没有给自己处理输入事件或intent广播的机会。
因此,在可能需要执行冗长操作的情况下,不应在界面线程中执行这些操作,而是应该创建工作线程并在其中执行大部分操作,让界面线程保持运行,阻止系统断定代码卡住。尤其是onCreate()
和 onResume()
等关键生命周期方法。
使用场景:
如果是数据库操作,应通过异步请求完成
1、/data/anr
下的转储文件
2、bugreport-BUILD_ID-DATE.txt
中查找am_anr
06-28 18:23:49.041 1000 1615 9666 I am_anr : [0,3297,com.android.systemui,818462221,Input dispatching timed out (eddf1c1 NavigationBar0 (server) is not responding. Waited 6293ms for MotionEvent(deviceId=4, source=0x00001002, displayId=0, action=DOWN, actionButton=0x00000000, flags=0x00000000, metaState=0x00000000, buttonState=0x00000000, classification=NONE, edgeFlags=0x00000000, xPrecision=1.0, yPrecision=1.0, xCursorPosition=nan, yCursorPosition=nan, pointers=[0: (499.3, 492.6)]), policyFlags=0x62000000)]
3、logcat日志中查找ANR in
找到ANR对应的堆栈跟踪,确定时间戳和PID,检查进程的主线程,主线程是了解ANR发生时系统正在做的事,不一定是导致ANR的真正原因。
线程 A 在等待线程 B 占用的某些资源,而线程 B 也在等待线程 A 占用的某些资源。
死锁的往往首先表现为ANR,日志中会有类似信息WATCHDOG KILLING SYSTEM PROCESS
。用户所见表现为设备重新启动,这种是运行时重启,并非真正的设备重新启动。(这两概念奇奇怪怪)
线程粘滞:执行时间超过“粘滞线程最长时间”(默认是600秒)的线程。
应用组件,提供屏幕与用户互动执行操作,activity通过 ActivityManager
运行进程
一个界面就是一个activity?
聚焦状态的activity,am_focused_activity
进程启动事件,Start proc
系统颠簸,am_proc_died
和am_proc_start
设备物理内存是有显示的,因为管理随机存取存储器很重要
内存不足时系统会终止某些进程来释放内存,但又会继续启动其他进程,因此可能导致系统颠簸。
内存不足还可能会减慢任务切换速度,并可能阻止进行返回尝试(返回任务被终止)。如果启动器被终止,那么,用户触摸主屏幕按钮时会重启,并在日志中记录启动器重新加载
am_low_memory
表示最后一个缓存的进程已终止
内存快照是一种dumpstate,其中会列出正在运行的JAVA进程和本机进程,快照仅提供特定时刻的状态,快照之前的系统状况不一定好/坏
应用生成广播,在当前应用内发送事件或向其他应用发送事件