Pourquoi cette alarme Android avec un crash intention en attente?
-
16-10-2019 - |
Question
J'ai un morceau très simple de code qui est utilisé pour planifier ma prochaine opération de synchronisation. Il est en cours d'exécution à l'intérieur du SyncAdapter qui étend AbstractThreadedSyncAdapter - utilise donc son contexte. Le PendingIntent il a commencé pour le BroadcastReceiver « MyService » qui ne gère que le SyncAdapter.
Je suis juste en train de le programmer pour se reproduire dans les 24 heures.
private void scheduleNextSync(Long timeFromNow) {
Intent intentSync = new Intent(getContext(), MyService.class);
intentSync.setAction(Intent.ACTION_SYNC);
intentSync.addCategory("android.provider.CONTACTS_STRUCTURE");
intentSync.putExtra(MySyncAdapter.EXTRA_SYNC_TYPE, "");
intentSync.putExtra(MySyncAdapter.EXTRA_RESOLVE_METAID, false);
int flags = 0;
int request = REQUEST_SYNC_ALL;
PendingIntent piSync = PendingIntent.getBroadcast(getContext(), request, intentSync, flags);
//
Log.i(TAG, "schedulePendingSync: " + piSync.toString());
AlarmManager alarm = (AlarmManager) getContext().getSystemService(Activity.ALARM_SERVICE);
alarm.set(request, SystemClock.elapsedRealtime() + timeFromNow, piSync);
}
sortie Log:
01-20 22:42:18.864 W/dalvikvm(14447): threadid=8: thread exiting with uncaught exception (group=0x40020950)
01-20 22:42:18.919 E/AndroidRuntime(14447): FATAL EXCEPTION: Thread-9
01-20 22:42:18.919 E/AndroidRuntime(14447): java.lang.NullPointerException
01-20 22:42:18.919 E/AndroidRuntime(14447): at android.os.Parcel.readException(Parcel.java:1253)
01-20 22:42:18.919 E/AndroidRuntime(14447): at android.os.Parcel.readException(Parcel.java:1235)
01-20 22:42:18.919 E/AndroidRuntime(14447): at android.app.IAlarmManager$Stub$Proxy.set(IAlarmManager.java:174)
01-20 22:42:18.919 E/AndroidRuntime(14447): at android.app.AlarmManager.set(AlarmManager.java:139)
01-20 22:42:18.919 E/AndroidRuntime(14447): at com.mysyncadpter.android.MySyncAdapter.scheduleNextSync(MySyncAdapter.java:145)
01-20 22:42:18.919 E/AndroidRuntime(14447): at com.mysyncadpter.android.MySyncAdapter.access$2(MySyncAdapter.java:131)
01-20 22:42:18.919 E/AndroidRuntime(14447): at com.mysyncadpter.android.MySyncAdapter$1.run(MySyncAdapter.java:123)
01-20 22:42:18.919 E/AndroidRuntime(14447): at java.lang.Thread.run(Thread.java:1096)
La solution
Votre PendingIntent.getBroadcast
et alarm.set
utiliser le REQUEST_SYNC_ALL
de demande
Je ne trouve pas que constante dans la alarme doc , ni PendingIntent doc .
Peut-être que je suis hors de synchronisation avec le dernier SDK:)
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow