programar - java.lang.RuntimeException: no se puede reanudar la actividad con java.lang.IllegalArgumentException
programar en java para android (2)
En el método Actividad # 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 ...
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 super class
XActivity
, solo
super.onResume();
.
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.
No hay suficiente información en su pregunta para determinar la causa de la excepción
java.lang.IllegalArgumentException
. Desafortunadamente, Android
ActivityThread
no registra el stacktrace de esa excepción, y el mensaje de excepción parece estar vacío.
Sin embargo, parece que hay un camino a seguir.
El código siguiente maneja la excepción 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 utilizar un método
onException
para registrar el stacktrace para la excepción causal.
Otra posibilidad es usar
Thread.setUncaughtExceptionHandler
para establecer un controlador para el subproceso en el que se lanza la
IllegalArgumentException
.
Estos no resolverán el problema (!) Pero lo acercarán un paso más a una solución.