BroadcastReceiver Vs WakefulBroadcastReceiver
¿Puede alguien explicar cuál es la diferencia exacta entre BroadcastReceiver
y WakefulBroadcastReceiver
?
¿En qué situaciones deberíamos usar cada clase de Receptor?
- ¿Cuándo Android parará su cpu sin el bloqueo de la estela?
- ¿Cómo las notificaciones necesitan WAKE_LOCK en android?
- ¿Hay alguna manera de recibir un evento de espera de la CPU en Android?
- conexión a internet en pausa después de bloqueo de teléfono android
- ¿Debo usar WakeLock en IntentService?
- WakeLock finalizó mientras seguía teniendo error aunque lo estoy lanzando
- OnStop llamado antes onStart
- Programación de Android: GCMIntentService Stuck at WakeLock
- ¿Es Wakelock de Android una necesidad para los servicios de fondo?
- Wake + Wifi bloqueo sin efecto
- ¿Cómo despertar android y mostrar la actividad?
- ¿Cómo desactiva Android Wear cuando está en modo de suspensión?
- Wakelock y wifilock no funcionan
Sólo hay una diferencia entre BroadcastReceiver
y WakefulBroadcastReceiver
.
Cuando recibe el método broadcast onReceive()
Suponer,
BroadcastReceiver :
- No se garantiza que la CPU se mantenga despierta si inicia algún proceso de ejecución prolongada. CPU puede volver inmediatamente a dormir.
WakefulBroadcastReceiver :
- Se garantiza que la CPU se mantendrá despierta hasta que dispare
completeWakefulIntent
.
Ejemplo:
Aquí, al recibir la emisión, está iniciando un servicio, ya que está usando WakefulBroadcastReceiver
, mantendrá wakelock
y no permitirá que la CPU duerma hasta que termine el trabajo dentro del servicio y el fuego completeWakefulIntent
Código:
public class SimpleWakefulReceiver extends WakefulBroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { // This is the Intent to deliver to our service. Intent service = new Intent(context, SimpleWakefulService.class); // Start the service, keeping the device awake while it is launching. Log.i("SimpleWakefulReceiver", "Starting service @ " + SystemClock.elapsedRealtime()); startWakefulService(context, service); } } class SimpleWakefulService extends IntentService { public SimpleWakefulService() { super("SimpleWakefulService"); } @Override protected void onHandleIntent(Intent intent) { // At this point SimpleWakefulReceiver is still holding a wake lock // for us. We can do whatever we need to here and then tell it that // it can release the wakelock. This sample just does some slow work, // but more complicated implementations could take their own wake // lock here before releasing the receiver's. // // Note that when using this approach you should be aware that if your // service gets killed and restarted while in the middle of such work // (so the Intent gets re-delivered to perform the work again), it will // at that point no longer be holding a wake lock since we are depending // on SimpleWakefulReceiver to that for us. If this is a concern, you can // acquire a separate wake lock here. for (int i=0; i<5; i++) { Log.i("SimpleWakefulReceiver", "Running service " + (i+1) + "/5 @ " + SystemClock.elapsedRealtime()); try { Thread.sleep(5000); } catch (InterruptedException e) { } } Log.i("SimpleWakefulReceiver", "Completed service @ " + SystemClock.elapsedRealtime()); SimpleWakefulReceiver.completeWakefulIntent(intent); } }
- ¿Actualización de esquema GreenDAO y migración de datos?
- Cómo devolver un resultado a través de múltiples actividades