我已经看过很多关于 ClassNotFoundException 和 Android 的帖子,但我还没有找到我认为是我所经历的原因。
我在 Android 市场上有一个应用程序 -数据计数器小部件。它有 250k+ 的下载量,每次我发布一个新版本时,我都会在 Android Market 的开发者控制台中收到少量 (1-5) 份关于 ClassNotFoundException 的错误报告。
29 份报告来自未指定(“其他”)设备,而 2 份来自 Nexus One。有两条用户消息:“启动时崩溃”和“更新安装期间”。
所有报告都是关于我的接收器(扩展广播接收器)。其中一个接收器相对频繁地被触发,因为它是启动读取和存储 Android 设备数据使用情况的服务的接收器。我有这种感觉,可能是为接收器设置了警报(使用 AlarmManager),然后用户/设备升级了应用程序并且找不到该类 - 可能是因为它位于不同的物理包中,或者它发生在设备进行交换的那一刻。会是这样吗?如果是这样,有没有办法解决它?我不明白为什么几乎所有的报告(比如 90%)都是在新版本发布后的同一天或接下来几天出现的。
我的一个接收器的堆栈跟踪(其他接收器除了类名之外提供相同的堆栈跟踪):
java.lang.RuntimeException: Unable to instantiate receiver com.roysolberg.android.datacounter.receivers.CounterReceiver: java.lang.ClassNotFoundException: com.roysolberg.android.datacounter.receivers.CounterReceiver in loader dalvik.system.PathClassLoader[/data/app/com.roysolberg.android.datacounter-1.apk]
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2789)
at android.app.ActivityThread.access$3200(ActivityThread.java:125)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2083)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4627)
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.ClassNotFoundException: com.roysolberg.android.datacounter.receivers.CounterReceiver in loader dalvik.system.PathClassLoader[/data/app/com.roysolberg.android.datacounter-1.apk]
at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2780)
... 10 more