AMS handleApplicationCrash函数的代码如下:
**ActivityManagerService.java::handleApplicationCrash**
~~~
public void handleApplicationCrash(IBinder app,
ApplicationErrorReport.CrashInfocrashInfo) {
//找到对应的ProcessRecord信息,后面那个字符串“Crash”用于打印输出
ProcessRecord r = findAppProcess(app, "Crash");
finalString processName = app == null ? "system_server"
: (r == null ? "unknown": r.processName);
//添加crash信息到dropbox中
ddErrorToDropBox("crash", r, processName, null, null, null,null, null,
crashInfo);
//调用crashApplication函数
crashApplication(r, crashInfo);
}
~~~
上述代码中的crashApplication 函数的代码如下:
**ActivityManagerService.java::crashApplication**
~~~
private void crashApplication(ProcessRecord r,
ApplicationErrorReport.CrashInfocrashInfo) {
longtimeMillis = System.currentTimeMillis();
//从应用进程传递过来的crashInfo中获取相关信息
StringshortMsg = crashInfo.exceptionClassName;
StringlongMsg = crashInfo.exceptionMessage;
StringstackTrace = crashInfo.stackTrace;
if(shortMsg != null && longMsg != null) {
longMsg = shortMsg + ": " + longMsg;
} elseif (shortMsg != null) {
longMsg = shortMsg;
}
AppErrorResult result = new AppErrorResult();
synchronized (this) {
if(mController != null) {
//通知监视者。目前仅MonkeyTest中会为AMS设置监听者。测试过程中可设定是否一检测
//到App Crash即停止测试。另外,Monkey测试也会将App Crash信息保存起来
//供开发人员分析
}
final long origId =Binder.clearCallingIdentity();
if (r!= null && r.instrumentationClass != null) {
......// instrumentationClass不为空的情况
}
//①调用makeAppCrashingLocked处理,如果返回false,则整个处理流程完毕
if (r == null || !makeAppCrashingLocked(r,shortMsg, longMsg,
stackTrace)) {
......
return;
}
Message msg = Message.obtain();
msg.what = SHOW_ERROR_MSG;
HashMap data = new HashMap();
data.put("result", result);
data.put("app", r);
msg.obj = data;
//发送SHOW_ERROR_MSG消息给mHandler,默认处理是弹出一个对话框,提示用户某进程 //崩溃(Crash),用户可以选择“退出”或 “退出并报告”
mHandler.sendMessage(msg);
......
}//synchronized(this)结束
//下面这个get函数是阻塞的,直到用户处理了对话框为止。注意,此处涉及两个线程:
//handleApplicationCrash函数是在Binder调用线程中处理的,而对话框则是在mHandler所
//在线程中处理的
int res =result.get();
IntentappErrorIntent = null;
synchronized (this) {
if (r!= null)
mProcessCrashTimes.put(r.info.processName, r.info.uid,
SystemClock.uptimeMillis());
if (res== AppErrorDialog.FORCE_QUIT_AND_REPORT)
//createAppErrorIntentLocked返回一个Intent,该Intent的Action是
//"android.intent.action.APP_ERROR",指定接收者是app. errorReportReceiver
//成员,该成员变量在关键点makeAppCrashingLocked中被设置
appErrorIntent =createAppErrorIntentLocked(r, timeMillis,
crashInfo);
}//synchronized(this)结束
if(appErrorIntent != null) {
try {//启动能处理APP_ERROR的应用进程,目前的源码中还没有地方处理它
mContext.startActivity(appErrorIntent);
} ......
}
}
~~~
以上代码中还有一个关键函数makeAppCrashingLocked,其代码如下:
**ActivityManagerService.java::makeAppCrashingLocked**
~~~
private booleanmakeAppCrashingLocked(ProcessRecord app,
String shortMsg, String longMsg, String stackTrace) {
app.crashing = true;
//生成一个错误报告,存放在crashingReport变量中
app.crashingReport = generateProcessError(app,
ActivityManager.ProcessErrorStateInfo.CRASHED, null, shortMsg,
longMsg, stackTrace);
/*
在上边代码中,我们知道系统会通过APP_ERROR Intent启动一个Activity去处理错误报告,
实际上在此之前,系统需要为它找到指定的接收者(如果有)。代码在startAppProblemLocked
中,此处简单描述该函数的处理过程如下:
1 先查询Settings Secure表中“send_action_app_error”是否使能,如果没有使能,则
不能设置指定接收者
2 通过PKMS查询安装此Crash应用的应用是否能接收APP_ERROR Intent。必须注意
安装此应用的应用(例如通过“安卓市场”安装了该Crash应用)。如果没有,则转下一步处理
3 查询系统属性“ro.error.receiver.system.apps”是否指定了APP_ERROR处理者,如果
没有,则转下一步处理
4 查询系统属性“ro.error.receiver.default”是否指定了默认的处理者
5 处理者的信息保存在app的errorReportReceiver变量中
另外,如果该Crash应用正好是串行广播发送处理中的一员,则需要结束它的处理流程以
保证后续广播处理能正常执行。读者可参考skipCurrentReceiverLocked函数
*/
startAppProblemLocked(app);
app.stopFreezingAllLocked();
//调用handleAppCrashLocked做进一步处理。读者可自行阅读
returnhandleAppCrashLocked(app);
}
~~~
当App的Crash处理完后,事情并未就此结束,因为该应用进程退出后,之前AMS为它设置的讣告接收对象将被唤醒。接下来介绍AppDeathRecipientbinderDied的处理流程。
- 前言
- 第1章 搭建Android源码工作环境
- 1.1 Android系统架构
- 1.2 搭建开发环境
- 1.2.1 下载源码
- 1.2.2 编译源码
- 1.2.3 利用Eclipse调试system_process
- 1.3 本章小结
- 第2章 深入理解Java Binder和MessageQueue
- 2.1 概述
- 2.2 Java层中的Binder架构分析
- 2.2.1 Binder架构总览
- 2.2.2 初始化Java层Binder框架
- 2.2.3 addService实例分析
- 2.2.4 Java层Binder架构总结
- 2.3 心系两界的MessageQueue
- 2.3.1 MessageQueue的创建
- 2.3.2 提取消息
- 2.3.3 nativePollOnce函数分析
- 2.3.4 MessageQueue总结
- 2.4 本章小结
- 第3章 深入理解SystemServer
- 3.1 概述
- 3.2 SystemServer分析
- 3.2.1 main函数分析
- 3.2.2 Service群英会
- 3.3 EntropyService分析
- 3.4 DropBoxManagerService分析
- 3.4.1 DBMS构造函数分析
- 3.4.2 dropbox日志文件的添加
- 3.4.3 DBMS和settings数据库
- 3.5 DiskStatsService和DeviceStorageMonitorService分析
- 3.5.1 DiskStatsService分析
- 3.5.2 DeviceStorageManagerService分析
- 3.6 SamplingProfilerService分析
- 3.6.1 SamplingProfilerService构造函数分析
- 3.6.2 SamplingProfilerIntegration分析
- 3.7 ClipboardService分析
- 3.7.1 复制数据到剪贴板
- 3.7.2 从剪切板粘贴数据
- 3.7.3 CBS中的权限管理
- 3.8 本章小结
- 第4章 深入理解PackageManagerService
- 4.1 概述
- 4.2 初识PackageManagerService
- 4.3 PKMS的main函数分析
- 4.3.1 构造函数分析之前期准备工作
- 4.3.2 构造函数分析之扫描Package
- 4.3.3 构造函数分析之扫尾工作
- 4.3.4 PKMS构造函数总结
- 4.4 APK Installation分析
- 4.4.1 adb install分析
- 4.4.2 pm分析
- 4.4.3 installPackageWithVerification函数分析
- 4.4.4 APK 安装流程总结
- 4.4.5 Verification介绍
- 4.5 queryIntentActivities分析
- 4.5.1 Intent及IntentFilter介绍
- 4.5.2 Activity信息的管理
- 4.5.3 Intent 匹配查询分析
- 4.5.4 queryIntentActivities总结
- 4.6 installd及UserManager介绍
- 4.6.1 installd介绍
- 4.6.2 UserManager介绍
- 4.7 本章学习指导
- 4.8 本章小结
- 第5章 深入理解PowerManagerService
- 5.1 概述
- 5.2 初识PowerManagerService
- 5.2.1 PMS构造函数分析
- 5.2.2 init分析
- 5.2.3 systemReady分析
- 5.2.4 BootComplete处理
- 5.2.5 初识PowerManagerService总结
- 5.3 PMS WakeLock分析
- 5.3.1 WakeLock客户端分析
- 5.3.2 PMS acquireWakeLock分析
- 5.3.3 Power类及LightService类介绍
- 5.3.4 WakeLock总结
- 5.4 userActivity及Power按键处理分析
- 5.4.1 userActivity分析
- 5.4.2 Power按键处理分析
- 5.5 BatteryService及BatteryStatsService分析
- 5.5.1 BatteryService分析
- 5.5.2 BatteryStatsService分析
- 5.5.3 BatteryService及BatteryStatsService总结
- 5.6 本章学习指导
- 5.7 本章小结
- 第6章 深入理解ActivityManagerService
- 6.1 概述
- 6.2 初识ActivityManagerService
- 6.2.1 ActivityManagerService的main函数分析
- 6.2.2 AMS的 setSystemProcess分析
- 6.2.3 AMS的 installSystemProviders函数分析
- 6.2.4 AMS的 systemReady分析
- 6.2.5 初识ActivityManagerService总结
- 6.3 startActivity分析
- 6.3.1 从am说起
- 6.3.2 AMS的startActivityAndWait函数分析
- 6.3.3 startActivityLocked分析
- 6.4 Broadcast和BroadcastReceiver分析
- 6.4.1 registerReceiver流程分析
- 6.4.2 sendBroadcast流程分析
- 6.4.3 BROADCAST_INTENT_MSG消息处理函数
- 6.4.4 应用进程处理广播分析
- 6.4.5 广播处理总结
- 6.5 startService之按图索骥
- 6.5.1 Service知识介绍
- 6.5.2 startService流程图
- 6.6 AMS中的进程管理
- 6.6.1 Linux进程管理介绍
- 6.6.2 关于Android中的进程管理的介绍
- 6.6.3 AMS进程管理函数分析
- 6.6.4 AMS进程管理总结
- 6.7 App的 Crash处理
- 6.7.1 应用进程的Crash处理
- 6.7.2 AMS的handleApplicationCrash分析
- 6.7.3 AppDeathRecipient binderDied分析
- 6.7.4 App的Crash处理总结
- 6.8 本章学习指导
- 6.9 本章小结
- 第7章 深入理解ContentProvider
- 7.1 概述
- 7.2 MediaProvider的启动及创建
- 7.2.1 Context的getContentResolver函数分析
- 7.2.2 MediaStore.Image.Media的query函数分析
- 7.2.3 MediaProvider的启动及创建总结
- 7.3 SQLite创建数据库分析
- 7.3.1 SQLite及SQLiteDatabase家族
- 7.3.2 MediaProvider创建数据库分析
- 7.3.3 SQLiteDatabase创建数据库的分析总结
- 7.4 Cursor 的query函数的实现分析
- 7.4.1 提取query关键点
- 7.4.2 MediaProvider 的query分析
- 7.4.3 query关键点分析
- 7.4.4 Cursor query实现分析总结
- 7.5 Cursor close函数实现分析
- 7.5.1 客户端close的分析
- 7.5.2 服务端close的分析
- 7.5.3 finalize函数分析
- 7.5.4 Cursor close函数总结
- 7.6 ContentResolver openAssetFileDescriptor函数分析
- 7.6.1 openAssetFileDescriptor之客户端调用分析
- 7.6.2 ContentProvider的 openTypedAssetFile函数分析
- 7.6.3 跨进程传递文件描述符的探讨
- 7.6.4 openAssetFileDescriptor函数分析总结
- 7.7 本章学习指导
- 7.8 本章小结
- 第8章 深入理解ContentService和AccountManagerService
- 8.1 概述
- 8.2 数据更新通知机制分析
- 8.2.1 初识ContentService
- 8.2.2 ContentResovler 的registerContentObserver分析
- 8.2.3 ContentResolver的 notifyChange分析
- 8.2.4 数据更新通知机制总结和深入探讨
- 8.3 AccountManagerService分析
- 8.3.1 初识AccountManagerService
- 8.3.2 AccountManager addAccount分析
- 8.3.3 AccountManagerService的分析总结
- 8.4 数据同步管理SyncManager分析
- 8.4.1 初识SyncManager
- 8.4.2 ContentResolver 的requestSync分析
- 8.4.3 数据同步管理SyncManager分析总结
- 8.5 本章学习指导
- 8.6 本章小结