Partial wake locks are a mechanism in the PowerManager
API that lets
developers keep the CPU running after a device's display turns off (whether due
to system timeout or the user pressing the power button). Your app acquires a
partial wake lock by calling acquire()
with the PARTIAL_WAKE_LOCK
flag, or by using other APIs that acquire wake locks.
Excessive use of partial wake locks drains the device's battery because it
prevents the device from entering lower power states. Partial wake locks should
be used only when necessary and released as soon as no longer needed.
If your app uses partial wake locks excessively, you can use the guidance in this page to diagnose and fix the problem.
Your feedback is a crucial part of improving our documentation. Please give us your feedback using the following link:
Detect the problem
Android vitals can help you find out when your app's use of partial wake locks is excessive.
Android vitals
Android vitals can help improve your app's performance by alerting you via the Play Console when your app's use of partial wake locks is excessive.
Android vitals reports partial wake lock use as excessive when all of the partial wake locks, added together, run for 3 or more hours in 24-hour period.
Android vitals tracks time only if the wake lock is held when the app is in the background and does not have a foreground service.
Android vitals gives some exemptions to partial wake lock usage in scenarios where there is a clear user benefit of the partial wake lock, and there's no better way to achieve that result without the partial wake lock. In those cases, Android vitals might not count the partial wake lock time against the 3-hour limit. For example, if an app is playing audio for the user, there's a clear benefit to keeping the device awake and there's no way to play the audio without keeping the device awake. In that case, the partial wake lock time is not counted against the Android vitals.
If excessive partial wake locks occur in more than 5% of app sessions across all devices in a 28-day period, it can affect your app's visibility on Play once the metric is out of beta.
Once you're aware that your app has excessive partial wake locks, your next step is to address the issue.
Fix the problem
Because wake locks can drain the device battery, you shouldn't use wake locks if there's an alternative. The Choose the right API to keep the device awake documentation can help you find the best solution for your app.
If you do need to use a wake lock, follow wake lock best practices to make sure your wake locks don't hurt device efficiency. In particular, make sure every device you acquire is released, and release the lock as quickly as possible.
After fixing the problem in code, you can verify your fixes by using local wake lock debugging tools.
See also
Recommended for you
- Note: link text is displayed when JavaScript is off
- Frozen frames
- Run benchmarks in Continuous Integration
- Create and measure Baseline Profiles without Macrobenchmark