Gar*_* BN 9 performance android alarm alarmmanager
我使用以下代码设置重复警报(每5分钟一次).
public void SetAlarm(Context context)
{
AlarmManager am=(AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
Intent i = new Intent(context, Alarm.class);
PendingIntent pi = PendingIntent.getBroadcast(context, 0, i, 0);
am.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(), 1000 * 60 * 5, pi); // Millisec * Second * Minute
}
Run Code Online (Sandbox Code Playgroud)
似乎工作正常(它运行近20个小时),并在服务器中,我可以看到一些不断的消息到达.
然而,有些事情是关于时代的:我希望时间是每五分钟一次,而且似乎在服务器中我在不同的时间收到消息.
当手机处于睡眠模式(夜晚)时,我会在服务器收到消息时添加第一个序列:
05:13:51,
05:18:54,
05:24:54,
05:28:54,
05:33:51,
05:38:54,
05:52:45,
05:54:54,
05:58:52,
06:04:54,
06:08:54,
06:16:19,
06:18:54,
06:24:54,
06:28:54,
06:34:54,
06:48:42,
06:48:44,
06:58:54,
Run Code Online (Sandbox Code Playgroud)
我不时使用手机的另一个顺序是:
11:08:46,
11:13:45,
11:18:48,
11:23:52,
11:33:54,
11:38:47,
11:48:47,
11:58:47,
12:03:52,
12:08:45,
12:14:49,
12:18:43,
12:25:37,
12:28:41,
12:34:56,
12:38:47,
12:43:48,
12:48:56,
12:54:07,
12:58:48,
13:03:43,
13:08:56,
13:14:11,
13:18:55,
13:25:02,
13:28:45,
13:33:43,
13:44:57,
13:48:58,
13:54:57,
13:58:52,
14:03:58
Run Code Online (Sandbox Code Playgroud)
我注意到三种不同的异常现象:
跳过警报(例如服务器中两条消息之间的间隔为10分钟) - 对我来说似乎很好,可能是由于连接问题.
两条消息之间的模式为6分钟,然后是4分钟.您可以多次看到此模式.我假设操作系统会进行一些优化,例如,如果它每两分钟有一次其他警报(例如检查是否有新的电子邮件),它会一起运行它们(并且收音机只打开一次而不是二).
奇怪的间隔(我无法解释它们) - 你可以看到.
所以我的问题:
如何强制系统每5分钟运行一次(或者更加努力)?
奇怪的时机是什么原因?我写了我的想法,但这些只是想法.
谢谢!
| 归档时间: |
|
| 查看次数: |
3284 次 |
| 最近记录: |