首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

性能优化之 Wakeups

和你一起终身学习,这里是程序员 Android

本篇文章主要介绍 开发中的性能部分知识点,通过阅读本篇文章,您将收获以下内容:

过多的唤醒源wakeups

如何fix 过多唤醒源问题

最佳实践

1.过多的唤醒源wakeups

Wakeups是 AlarmManager API 中的一种机制 ,它可让开发人员在指定时间设置警报,进而达到唤醒设备的目的。您的应用通过使用 RTC_WAKEUP 或ELAPSED_REALTIME_WAKEUP 标志调用AlarmManager中的方法来设置唤醒警报。当触发唤醒警报后,设备将退出低功耗模式,并在执行警报 onReceive()或 onAlarm() 方法的同时holdspartial wake lock 。如果唤醒警报触发过多,它们可能会耗尽设备的电池电量。

为了帮助您提高应用程序质量,Android会自动监视应用程序是否存在过多的唤醒警报,并以Android vitals的形式显示信息。有关如何收集数据的信息,请参阅Play控制台文档。

如果您的应用过度唤醒设备,则可以使用此页面中的指导来诊断和解决问题。

2. 如何fix 过多唤醒源问题

AlarmManager 是在Android平台的早期版本中推出的,但随着时间的推移,以前需要很多 AlarmManager 的用例现在更好新功能提供服务(比如:WorkManager)。本部分包含有关减少唤醒警报的提示,但从长远来看,请考虑迁移您的应用以遵循第三节最佳实践部分中的建议。

确定您在应用中安排唤醒警报的位置,并减少触发这些警报的频率。这里有一些提示:

查找对包含RTC_WAKEUP 或 ELAPSED_REALTIME_WAKEUP 标志的各种 AlarmManager set() 方法的调用 。

我们建议您将包,类或方法的名称包括在警报的标记名称中,以便您可以轻松地在源中识别设置警报的位置。以下是一些其他提示:

忽略名称中的任何个人身份信息(PII),例如电子邮件地址。否则,设备将记录日志而不是警报名称。

不要以编程方式获取类或方法的名称,例如通过调用 getName() ,因为Proguard可能会混淆它们。而是使用硬编码的字符串。

不要在警报标签中添加计数器或唯一标识符。系统将无法聚合以这种方式设置的警报,因为它们都具有唯一的标识符。

解决问题后,通过运行以下ADB 命令来验证唤醒警报是否按预期工作:

该命令提供有关设备上警报系统服务状态的信息。有关更多信息,请参见 dumpsys。

3. 最佳实践

仅当您的应用需要执行面向用户的操作(例如发布通知或提醒用户)时,才使用唤醒警报。有关AlarmManager最佳做法的列表,请参阅Scheduing Repeating Alarms。

不要 AlarmManager

用于安排后台任务,尤其是重复的或网络后台任务。建议使用 WorkManager 执行后台任务,因为它具有以下优点:

批处理-合并作业,以减少电池消耗

持久性-如果重新启动设备,则在重新启动完成后运行计划的WorkManager作业

条件-作业可以根据条件运行,例如设备是否正在充电或WiFi是否可用

有关更多信息,请参阅《后台处理指南》。

不要 AlarmManager 用于安排仅在应用程序运行时才有效的计时操作(换句话说,当用户退出应用程序时应取消计时操作)。在这种情况下,请使用 Handler 该类,因为它更易于使用且效率更高。

友情推荐

至此,本篇已结束,如有不对的地方,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20191022A05XW900?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券