Android SetInexactRepeating根本没有触发

时间:2012-07-30 19:14:41

标签: android android-intent alarmmanager repeat android-pendingintent

我在我的onCreate中放置了一个永远不会触发的android setInexactRepeating。我在其中有一个日志,以确保它实际上正在执行,并且似乎没有触发,以及我为它计划的事件。我希望它每隔10秒就会消失一次,但它甚至连第一次都没有消失。

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    Log.d("Restart", "First");
    Intent toRun = new Intent(this, AlarmRestart.class);
    PendingIntent pendingToRun = PendingIntent.getBroadcast(this, 0, toRun, 0);
    AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);
    am.cancel(pendingToRun); 
    am.setInexactRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, System.currentTimeMillis(), 10000L, pendingToRun);

    Log.d("Restart", "Second");
}

这是在另一个文件中:

public class AlarmRestart extends BroadcastReceiver {
    public void onReceive(Context context, Intent intent) {
        Log.d("Restart", "Third");
    }
}

这就是“adb shell dumpsys alarm”所说的

com.packageName.restart
5715ms running, 64 wakeups
3 alarms: flg=0x14 cmp=com.packageName.restart/.AlarmRestart
61 alarms: flg=0x14 cmp=com.packageName.restart/.reciever.AlarmRestart

3 个答案:

答案 0 :(得分:8)

AlarmRestartBroadcastReceiver。它不是Service。但您尝试使用getService() PendingIntent。那样不行。将getService()更改为getBroadcast(),您应该有更好的运气。

答案 1 :(得分:4)

我发现了问题:/

        <reciever android:name="com.appName.restart.AlarmRestart" android:enabled="true" />

它是拼写的接收器......不是接收器。说真的,XML需要一个错误检查器。我仍然将CommonWares的答案标记为已接受的答案,因为他解决了我将在以后遇到的其他几个问题。

答案 2 :(得分:1)

您可以在ELAPSED_REALTIME_WAKEUP警报中使用SystemClock.elapsedRealtime(),而不是System.currentTimeMillis()