Я создал манекен IntentService
, который работает на переднем плане, который, по существу, регистрирует, сколько времени он проснулся каждые 5 секунд. Это длилось несколько часов на тестовом устройстве, не требуя никаких разрешений WakeLock
. Кроме того, это, похоже, не повредит время автономной работы. Не отображается при использовании даже 1% батареи в батареях на устройстве. Как эта служба может работать без необходимости WakeLock
?Почему мой IntentService не требует WakeLock?
Обновление: Некоторое интересное поведение я заметил из этого. Кажется, что служба действительно собирается спать, но на довольно непоследовательной основе. Оглядываясь назад на некоторые из операторов журналов, вы можете видеть, что хотя поток спал только 5 секунд, а затем просыпаясь, система, похоже, приостанавливает обслуживание. Обратите внимание, что время прыгает с 17:56:31 до 17:56:54 до 17:57:05. 23-секундный прыжок с последующим прыжком в 9 секунд. Объяснение, почему это было бы наиболее полезно. Спасибо.
12-01 17:56:31.479 8723-8780/com.example.timedrift D/Done Sleeping﹕ Active for 2375000 Seconds
12-01 17:56:54.630 8723-8780/com.example.timedrift D/Done Sleeping﹕ Active for 2380000 Seconds
12-01 17:57:05.632 8723-8780/com.example.timedrift D/Done Sleeping﹕ Active for 2385000 Seconds
12-01 17:57:11.097 8723-8780/com.example.timedrift D/Done Sleeping﹕ Active for 2390000 Seconds
12-01 17:57:16.098 8723-8780/com.example.timedrift D/Done Sleeping﹕ Active for 2395000 Seconds
12-01 17:58:00.829 8723-8780/com.example.timedrift D/Done Sleeping﹕ Active for 2400000 Seconds
IntentService:
@Override
protected void onHandleIntent(Intent intent) {
Notification notification = new Notification(R.drawable.ic_launcher, "Time",
System.currentTimeMillis());
Intent notificationIntent = new Intent(this, MainActivity.class);
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, notificationIntent, 0);
notification.setLatestEventInfo(this, "Time",
"Time", pendingIntent);
startForeground(100, notification);
SharedPreferences sharedPrefs = PreferenceManager.getDefaultSharedPreferences(this);
SharedPreferences.Editor editor = sharedPrefs.edit();
try {
Log.d("TimerService", "Start");
int i = 1;
while(true){
Thread.sleep(5000);
int numberOfSeconds = i++*5;
Log.d("Done Sleeping", String.valueOf("Active for "+numberOfSeconds+" Seconds"));
editor.putLong(String.valueOf(numberOfSeconds), numberOfSeconds);
editor.apply();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
Некоторые связанные с этим объяснения http://android.stackexchange.com/questions/69693/how-do-timers-and-alarms-function-while-the-device-is-sleeping – zapl