2013-05-13 1 views
0

Я вижу исключение, когда ActivityManager.isUserAMonkey() будет работать на старом Android устройств:Android.isUserAMonkey бросает RuntimeException

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.myapp.AndroidApp}: java.lang.RuntimeException: Unknown exception code: 1 msg null 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2781) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2797) 
    at android.app.ActivityThread.access$2300(ActivityThread.java:135) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2132) 
    at android.os.Handler.dispatchMessage(Handler.java:99) 
    at android.os.Looper.loop(Looper.java:143) 
    at android.app.ActivityThread.main(ActivityThread.java:4914) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:521) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
    at dalvik.system.NativeStart.main(Native Method) 
Caused by: java.lang.RuntimeException: Unknown exception code: 1 msg null 
    at android.os.Parcel.readException(Parcel.java:1257) 
    at android.os.Parcel.readException(Parcel.java:1235) 
    at android.app.ActivityManagerProxy.isUserAMonkey(ActivityManagerNative.java:2762) 
    at android.app.ActivityManager.isUserAMonkey(ActivityManager.java:990) 
    at <com.myapp....> ... 

Существует немного обсуждения ошибки здесь (в том числе классического Thats-не-возможного ответа от один из разработчиков: «в стандартной реализации платформы это в значительной степени не представляется возможным.»)

https://groups.google.com/forum/?fromgroups=#!topic/android-developers/tQJcM4O4WxM

Ее мне не ясно, если это всегда бывает, или бывает только при работе в тестовом м onkey, или только на некоторых устройствах или что. (Я столкнулся с этой проблемой, используя службу тестирования устройств Apkudo, где пользователь всегда является обезьяной.) Неясно, когда это было исправлено, либо (это не происходит на большинстве (всех?) Новых устройств).

ответ

0

Исключение похоже на версии для Android 2.2 (SDK версии 8). И, кажется, была ошибка в android.app.ActivityManagerNative.

Вот 2,2,1 кода (находятся в ActivityManagerNative.java on grepcode.com):

1248  case IS_USER_A_MONKEY_TRANSACTION: { 
1249   data.enforceInterface(IActivityManager.descriptor); 
1250   reply.writeInt(isUserAMonkey() ? 1 : 0); 
1251   reply.writeNoException(); 
1252   return true; 
1253  } 

Вот 2.3.1 кода (который, кажется, так же, как гораздо более поздней код 4, который я знаю, работает корректно) , (Также found on grepcode.com):

1248  case IS_USER_A_MONKEY_TRANSACTION: { 
1239   data.enforceInterface(IActivityManager.descriptor); 
1240   boolean areThey = isUserAMonkey(); 
1241   reply.writeNoException(); 
1242   reply.writeInt(areThey ? 1 : 0); 
1243   return true; 
1244  } 

Обратите внимание на порядок writeNoException и writeInt перепутаны в новой коде. Соответствующий код для чтения посылки, кажется неизменным с 2.2.1 насколько я могу сказать:

2749 public boolean isUserAMonkey() throws RemoteException { 
2750  Parcel data = Parcel.obtain(); 
2751  Parcel reply = Parcel.obtain(); 
2752  data.writeInterfaceToken(IActivityManager.descriptor); 
2753  mRemote.transact(IS_USER_A_MONKEY_TRANSACTION, data, reply, 0); 
2754  reply.readException(); 
2755  boolean res = reply.readInt() != 0; 
2756  data.recycle(); 
2757  reply.recycle(); 
2758  return res; 
2759 } 

Эта сторона читает исключение, а затем ожидает данные.

Javadoc для ParcelreadException и writeException означает, что они записывают исключение в заголовке парцелла (и, следовательно, не должны влиять на фактические данные посылки), но это, кажется, порядок имеет значение.

Это означает, что в SDK версии 8 API ActivietyManager.isUserAMonkey() будет всегда выбросить исключение, обезьяна или нет. Android строит после того, как SDK 8 не должен выбрасывать это исключение.

Я подозреваю, что сообщение об исключении SDK 8 может немного отличаться без обезьяны («1 msg null» по сравнению с «0 msg null»?), Но не имеет примера исключения без запуска обезьяны.

 Смежные вопросы

  • Нет связанных вопросов^_^