观看视频里的看开机后11:03的时候就界面亮屏
从log中看: 10-19 11:04:07 才开始启动 APP
10-19 11:04:07.472 I/ActivityManager( 954): Start proc 9004:com.xxx.xxx/u0a49 for broadcast
{com.xxx.xxx/com.xxx.xxx.widget.WeatherWidget}
从启动APP 到 APP Widget 完成各种初始化并最终显示用了 最后一个更新时间
10-19 11:04:09.319 D/WeatherWidget( 9004): action:android.appwidget.action.APPWIDGET_UPDATE
大概耗时2S做哟的时间。所以大量时间耗费在启动app之前
【问题根因】进程启动慢导致,具体定位是由于
【act=android.appwidget.action.APPWIDGET_UPDATE】
广播拉起慢导致,通过dumpsys activity broadcasts,也确实看到了此action属于后台广播。
【解决方案】将广播APPWIDGET_UPDATE提升至前台广播。
/framework/base/services/appwidget/java/com/adnroid/server/appwidget/AppWidgetServiceImpl.java
private void sendUpdateIntentLocked(Provider provider, int[] appWidgetIds) {
Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, appWidgetIds);
intent.setComponent(provider.id.componentName);
intent.addFlags(Intent.FLAG_RECEIVER_FOREGROUND);//将APPWIDGET_UPDATE提升至前台广播。
sendBroadcastAsUser(intent, provider.id.getProfile());
}
博客分析了启动APP时界面亮屏与APP实际启动之间的延迟,发现主要原因是`android.appwidget.action.APPWIDGET_UPDATE`广播拉起慢导致。通过dumpsys activity broadcasts确认该广播为后台广播。解决方案是将APPWIDGET_UPDATE提升至前台广播,修改AppWidgetServiceImpl.java文件,添加FLAG_RECEIVER_FOREGROUND标志,从而缩短启动时间。
854

被折叠的 条评论
为什么被折叠?



