Recientemente, a veces recibí esta excepción cuando MainActivity llamó a onResume().
java.lang.RuntimeException: Unable to resume activity {com.qau4d.c35s3.androidapp/com.xxx.XXX.XXX.MainActivity}: java.lang.IllegalArgumentException at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3400) at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3440) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1510) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:154) at android.app.ActivityThread.main(ActivityThread.java:6077) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755) Caused by: java.lang.IllegalArgumentException at android.os.Parcel.readException(Parcel.java:1687) at android.os.Parcel.readException(Parcel.java:1636) at android.app.ActivityManagerProxy.isTopOfTask(ActivityManagerNative.java:5475) at android.app.Activity.isTopOfTask(Activity.java:5961) at android.app.Activity.onResume(Activity.java:1252) at com.qau4d.c35s3.androidapp.onResume(XActivity.java:29) at com.qau4d.c35s3.androidapp.onResume(MainActivity.java:196) at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1269) at android.app.Activity.performResume(Activity.java:6768) at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3377)
Tanto en MainActivity
como en la superclase XActivity
, solo super.onResume();
se llama. Es realmente extraño obtener esta excepción después de un desarrollo normal durante mucho tiempo. Revisé algunos materiales de referencia relativos pero no obtuve nada.
En el método Activity#isTopOfTask podemos ver:
private boolean isTopOfTask() { if (mToken == null || mWindow == null) { return false; } try { return ActivityManager.getService().isTopOfTask(getActivityToken()); } catch (RemoteException e) { return false; } }
Y en ActivityManagerService#isTopOfTask podemos encontrar:
@Override public boolean isTopOfTask(IBinder token) { synchronized (this) { ActivityRecord r = ActivityRecord.isInStackLocked(token); if (r == null) { throw new IllegalArgumentException(); } return r.task.getTopActivity() == r; } }
Entonces, creo que ActivityRecord es nulo. Pero no sé por qué es nulo...
No hay información suficiente en su pregunta para determinar la causa de java.lang.IllegalArgumentException
. Desafortunadamente, Android ActivityThread
no registra el seguimiento de pila de esa excepción, y el mensaje de excepción parece estar vacío.
Sin embargo, parece que hay un camino a seguir. La excepción es manejada por el siguiente código en el método ActivityThread::performResumeActivity
:
} catch (Exception e) { if (!mInstrumentation.onException(r.activity, e)) { throw new RuntimeException( "Unable to resume activity " + r.intent.getComponent().toShortString() + ": " + e.toString(), e); } }
Si registra una clase de Instrumentation
para su actividad, debería ser posible usar un método onException
para registrar el seguimiento de la pila para la excepción causal. Otra posibilidad es usar Thread.setUncaughtExceptionHandler
para establecer un controlador para el subproceso en el que se lanza IllegalArgumentException
.
Esto no resolverá el problema (!), pero lo acercará un paso más a la solución.