使用打盹模式在前台服务中禁用唤醒锁定 - Android M中的新电池优化

时间:2015-11-14 13:43:41

标签: android android-6.0-marshmallow

这显然是半记录的行为,如果Dianne Hackborn对G +帖子的评论构成"记录":https://plus.google.com/+AndroidDevelopers/posts/94jCkmG4jff但是应该允许与通知图标关联的前台服务保持警觉在打盹模式下锁定。

除了前台服务之外,如果您有顶级活动,这似乎无效。

我创建了一个最小的实现来演示: https://github.com/petrnalevka/dozetest/blob/master/src/com/urbandroid/doze/DozeService.java

问题可以转载于 Android M,MRA58K Nexus 5和MRA58N Nexus 6

我的前台服务有一个相关的通知,我持有部分唤醒锁。不幸的是,打盹模式接管了我的唤醒锁定。我只能通过退出电池优化或退出最高活动来阻止这种情况。

我认为这是Android中的一个错误,因为没有理由为前台服务保留唤醒锁定,但如果他们在顶部有活动则没有。

我已经将这个问题放在了SO上,即使我已经在Androdi问题跟踪器https://code.google.com/p/android/issues/detail?id=193802上报告了这一点,以便找到解决方法,因为这是一个非常重要的功能,以便不需要REQUEST_IGNORE_BATTERY_OPTIMIZATIONS,这显然只是目前意味着REQUEST_REMOVAL_FROM_PLAYSTORE_BY_GOOGLE。

以下是我使用adb重现问题的方法,感谢+ Dianne Hackborn的提示:

似乎当我将一个Activity保留在前台,同时还有运行我的应用程序的前台服务时,电源管理器会将其识别为:

PARTIAL_WAKE_LOCK              'Doze lock' DISABLED (uid=10112, pid=24649, ws=null)  
Proc # 0: fore  F/A/TS trm: 0 24649:com.urbandroid.doze/u0a112 (top-activity)  

如果我按回家离开活动,我会进入状态:

PARTIAL_WAKE_LOCK              'Doze lock' (uid=10112, pid=24649, ws=null)  
Proc # 4: prcp  F/S/SF trm: 0 24649:com.urbandroid.doze/u0a112 (fg-service)  

1 个答案:

答案 0 :(得分:7)

这是Dianne Hackborn在https://plus.google.com/+AndroidDevelopers/posts/94jCkmG4jff下发表的回答。我们仍然可以在这里集思广益,因为分离流程可能并不总是直截了当。

Dianne Hackborn: + Petr Nalevka很抱歉,这似乎是平台上的一个错误。我会尽可能地修复它。

你的解决方法是正确的方向,但请不要在屏幕开/关中移动你的状态。好吧,当屏幕关闭时可以向后移动并做到这一点...但是,当屏幕打开时强迫自己到前面是非常错误的,因为它可能因其他原因而打开(到发射相机,语音交互等)。这实际上可能是平台应该更好地保护自己。

我建议的是开始打瞌睡模式,并在这种情况下将你的活动放在后面。您可以通过侦听广播http://developer.android.com/reference/android/os/PowerManager.html#ACTION_DEVICE_IDLE_MODE_CHANGED并在看到设备空闲为真时将自己发送到后面来实现。我建议不要担心试图让自己回到前台 - 在用户实际上很长一段时间没有使用他们的设备并且发生这种情况的情况下,回到它并且在家里不应该是一个惊喜。

编辑(作者:Dianne Hackborn):实际上,另一种解决方案 - 让您的前台服务在与活动不同的过程中运行。从我所看到的,这将工作正常。如果你在那里得到了理想的行为,我会很有趣。

这实际上也是我们建议的做法 - 如果你有一个长期运行的前台服务,它应该在与活动不同的进程中,所以它不会强制所有与活动相关的内存被留下来。 (这也是这个bug通过的原因,我们所有的应用程序都使用这种模式。)