情景:Android8.1 开机向导完成后,进入到launcher,前几秒内,重启机器,发现开机向导又被启动了
原因:系统写入禁用配置文件加了10s延时,所以在10s内重启机器就会出现此问题…
源码:
setEnabledSetting()方法中调用scheduleWritePackageRestrictionsLocked()来写入禁用配置文件中加了10s延时,源码如下:
// frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java
static final int WRITE_SETTINGS_DELAY = 10*1000; // 10 seconds
void scheduleWritePackageRestrictionsLocked(int userId) {
final int[] userIds = (userId == UserHandle.USER_ALL)
? sUserManager.getUserIds() : new int[]{userId};
for (int nextUserId : userIds) {
if (!sUserManager.exists(nextUserId)) return;
mDirtyUsers.add(nextUserId);
if (!mHandler.hasMessages(WRITE_PACKAGE_RESTRICTIONS)) {
mHandler.sendEmptyMessageDelayed(WRITE_PACKAGE_RESTRICTIONS, WRITE_SETTINGS_DELAY);
}
}
}
// Handler处理
case WRITE_PACKAGE_RESTRICTIONS: {
Process.setThreadPriority(Process.THREAD_PRIORITY_DEFAULT);
synchronized (mPackages) {
removeMessages(WRITE_PACKAGE_RESTRICTIONS);
for (int userId : mDirtyUsers) {
mSettings.writePackageRestrictionsLPr(userId); // 写入禁用配置文件
}
mDirtyUsers.clear();
}
Process.setThreadPriority(Process.THREAD_PRIORITY_BACKGROUND);
} break;
// frameworks/base/services/core/java/com/android/server/pm/Settings.java (androidxref.com)
可以通过adb命令读取文件内容:
cat /data/system/users/0/package-restrictions.xml | grep setup
更深层的原因,需要研究下PMS相关知识,后续补充