我的应用使用闹钟定时器每2分钟左右检查服务器上的更新。我用这个创建了一个定期计时器:
alarmIntent = new Intent(context, OnWakeUpReceiver.class);
PendingIntent pIntent = PendingIntent.getBroadcast(context, 0, alarmIntent, 0);
mAlarmManager.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(), 120000, pIntent);
对绝大多数人来说,这很好用。但是有少数人报告该应用程序突然停止更新。我进行了简单的检查,看看计时器是否存在:
PendingIntent pIntent = PendingIntent.getBroadcast(context, 0, alarmIntent, PendingIntent.FLAG_NO_CREATE);
当然,当应用程序不再更新时,返回null,表示没有计时器仍然存在。
我的应用程序一直在控制闹钟定时器(当没有网络连接时将其关闭,然后在有其他情况时将其重新打开)。我想也许我在某种程度上把它关掉而不是把它重新打开。所以我创建了一个版本,我删除了每个调用以取消闹钟定时器。所以我的应用程序不再有任何取消该计时器的方法。但是在几天之后,警报计时器再次出现,并且应用程序没有更新。
我无法在我自己的系统上实现这一点,或者让某人找到一种万无一失的方式在他们的系统上重复它。我想知道Android系统是否正在取消它(虽然这会阻止我的应用程序再次运行),但在一个更多的问题系统上,他说他手机上几乎没有任何东西在运行。
我不知道任务杀手是否也可以杀死闹钟定时器,但是我知道在我认为SDK 8之后,任务杀手无论如何都无法做到这一点,而且我在发布第8版时遇到了问题。而且在没有运行任务杀手的系统上,并且还没有扎根。
我甚至创建了一个“看门狗”闹钟定时器,它只运行一个接收器来查看主应用定时器是否已经停止更新。我发现那个计时器也被取消了(它没有进一步的“最后运行”更新,并且从未注意到主应用程序已停止)。
这个问题对我来说是一个app杀手。任何人都可以建议任何方式甚至尝试调试何时以及发生了什么?当计时器被取消时,系统是否有任何日志条目,无论是系统还是其他东西?我讨厌它只是消失得无影无踪。
答案 0 :(得分:1)
我不能说这是完整的答案,但这两个变化似乎已经停止了大部分被取消的警报:
1)当我不得不因任何原因取消闹钟时,我正在接受待处理的意图并取消它,而不是在闹钟管理器上调用cancel()。随着时间的推移,我不知道是否设法混淆了警报管理器或其他东西,但它可能并不好。现在我取消了警报管理器以及待处理的意图。
2)我的一位用户提到他们如何点击Clear RAM,它会禁用我的服务。显然有些手机带有一个任务管理器,它给了他们一个漂亮的闪亮按钮,让他们清理内存/ RAM。按钮甚至清楚地说明按下它会导致一些应用程序停止工作......并且仍然是用户将其混合。我不知道究竟是怎么回事,但这似乎最让我失去警报。所以我发布了一个重要的通知,让人们停止这样做,从那以后事情真的安静了下来。可怕的一面是,如果用户点击了死亡的魔法按钮,或者出现了什么问题,我下次遇到残疾警报时,我真的不知道。
但不管怎样,现在事情变得更好了。