2013-05-13 89 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....> ... 

有一點的錯誤的討論在這裏(包括從經典這就是 - 不響應可能開發商之一:「在標準平臺的實現,這是非常不可能的。」)

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

它不是我清楚,如果這總是會發生,或者只發生一個試驗M下運行時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.x的代碼,我正確認識作品) 。 (另外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  } 

通知writeNoExceptionwriteInt的順序在較新的代碼是相反的。對應的代碼讀取包裹似乎是因爲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 } 

此方首先讀取異常,那麼預計該數據。

對於ParcelreadExceptionwriteException的javadoc暗示它們在包裹標題中記錄異常(因此不應影響包裹中的實際數據),但似乎順序確實很重要。

這意味着SDK版本8的ActivietyManager.isUserAMonkey() API將總是拋出一個異常,猴子與否。 Android SDK在SDK 8之後不會拋出這個異常。

我懷疑沒有猴子(「1 msg null」與可能是「0 msg null」?)的SDK 8異常消息可能會略有不同,但沒有沒有運行猴子的例外情況。

相關問題