我有一个广播接收器设置,以便在每次升级我的应用程序后,或者如果这是首次安装该包时弹出消息显示给用户。我在我的运行Android 2.2的Droid上测试了这一点,既作为全新安装,也作为升级我的应用程序之后,以及运行1.5和1.6的模拟器,并且我看到一切正常运行。安卓广播接收器错误:类未找到异常
不过,我收到一个列出以下异常的用户的错误报告:
java.lang.RuntimeException: Unable to instantiate receiver
com.name.pkg.FirstRunBroadcastReceiver: java.lang.ClassNotFoundException: com.name.pkg.app_name.FirstRunBroadcastReceiver in loader dalvik.system.PathClassLoader[/data/app/com.name.pkg.app_name.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:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: com.name.pkg.app_name.FirstRunBroadcastReceiver in loader dalvik.system.PathClassLoader[/data/app/com.name.pkg.app_name.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
谁能告诉我为什么我的用户之一收到此异常?
在我的清单文件,我有事情设置是这样的:
<receiver android:name=".FirstRunBroadcastReceiver">
<intent-filter>
<action android:name="android.intent.action.PACKAGE_REPLACE"/>
<data android:scheme="package" android:path="com.name.pkg.app_name">
</intent-filter>
</receiver>
类FirstRunBroadcastReceiver是设置这样的:
package com.name.pkg.app_name;
public class FirstRunBroadcastReceiver extends BroadcastReceiver
{
@Override
public void onReceive(Contenxt context, Intent intent)
{
Uri uri = intent.getData();
if(uri.toString().compareTo("package:com.name.pkg.app_name") == 0)
{
//set shared prefs data to determine if start-up message should be shown
}
}
}
在第一次安装,用于共享的缺省值prefs被设置为弹出消息将被显示,但我不认为这与这个异常有什么关系。
我再次测试它,并且我没有收到异常。感谢您的任何帮助,您可以提供。
这是这个用户的持续的事情吗?还是只发生过一次? – Falmarri 2010-08-24 17:49:35
嗨Falmarri,不幸的是,我不知道这是否是一个连续的例外。我通过Android Market获得了报告。无论谁遇到这个错误,都不会给我发电子邮件,这本来不错。所以我只是不知道。在我的市场帐户中只有一个错误报告,但这并不一定意味着什么。 – Michael 2010-08-24 19:58:29
你解决了这个问题吗? - 发表一个答案。 – levi 2014-08-07 01:41:25