25

Ricevo questa eccezione nel mio codice indicato di seguito. non ho idea di cosa c'è di sbagliato in questo codice. Per favore aiutami a sbarazzarmi di questa eccezione.BroadcastReceiver che tenta di restituire il risultato durante una trasmissione non ordinata - PACKAGE_ADDED in Android

05-23 23:33:49.853: E/BroadcastReceiver(26895): BroadcastReceiver trying to return result during a non-ordered broadcast 
05-23 23:33:49.853: E/BroadcastReceiver(26895): java.lang.RuntimeException: BroadcastReceiver trying to return result during a non-ordered broadcast 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.content.BroadcastReceiver.checkSynchronousHint(BroadcastReceiver.java:783) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.content.BroadcastReceiver.setResultCode(BroadcastReceiver.java:549) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at com.waypedia.rupesh.abhi.RetentionApplicationAddedBroadcastReceiver.onReceive(RetentionApplicationAddedBroadcastReceiver.java:18) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.app.ActivityThread.handleReceiver(ActivityThread.java:2446) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.app.ActivityThread.access$1700(ActivityThread.java:139) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1286) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.os.Handler.dispatchMessage(Handler.java:102) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.os.Looper.loop(Looper.java:136) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at android.app.ActivityThread.main(ActivityThread.java:5102) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at java.lang.reflect.Method.invokeNative(Native Method) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at java.lang.reflect.Method.invoke(Method.java:515) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) 
05-23 23:33:49.853: E/BroadcastReceiver(26895):  at dalvik.system.NativeStart.main(Native Method) 

Qui di seguito è il mio codice:

public class RetentionApplicationAddedBroadcastReceiver extends WakefulBroadcastReceiver { 
    @Override 
public void onReceive(Context context, Intent intent) { 

    ComponentName comp = new ComponentName(context.getPackageName(), 
      RetentionAddIntentService.class.getName()); 
    // Start the service, keeping the device awake while it is launching. 
    startWakefulService(context, (intent.setComponent(comp))); 
    setResultCode(Activity.RESULT_OK); //**LINE 18** 
} 

risposta

55

Elimina setResultCode(). Vale solo per l'uso con una trasmissione ordinata, come descritto in the documentation for setResultCode().

+8

Questo potrebbe non risolvere il problema per i dispositivi Android O. Mi sono sbarazzato di 'setResultCode()' nella mia classe, ottenendo comunque questo errore su Android O da WakefulBroadcastReceiver. –

+0

@IgorGanapolsky: Questo non ha molto senso, poiché l'errore specifico dovrebbe verificarsi solo impostando un risultato. Potresti prendere in considerazione la pubblicazione di una domanda di overflow dello stack separata con [mcve] (code + stack trace). – CommonsWare