Android: ClassNotFoundException 在将可序列化对象传递给 Activity 时的异常
我有一些来自Android市场的崩溃报告日志,类似于以下内容:
Exception class: java.lang.ClassNotFoundException
Source method: PathClassLoader.findClass()
java.lang.RuntimeException: Unable to start activity ComponentInfo{my.app.package/my.app.package.MyActivity}: java.lang.RuntimeException: Parcelable encounteredClassNotFoundException reading a Serializable object (name = my.app.package.a.ae)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2833)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2854)
at android.app.ActivityThread.access$2300(ActivityThread.java:136)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2179)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:5068)
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.RuntimeException: Parcelable encounteredClassNotFoundException reading a Serializable object (name = my.app.package.a.ae)
at android.os.Parcel.readSerializable(Parcel.java:1951)
at android.os.Parcel.readValue(Parcel.java:1822)
at android.os.Parcel.readMapInternal(Parcel.java:2008)
at android.os.Bundle.unparcel(Bundle.java:208)
at android.os.Bundle.getBundle(Bundle.java:1078)
at android.app.Activity.onRestoreInstanceState(Activity.java:861)
at android.app.Activity.performRestoreInstanceState(Activity.java:835)
at android.app.Instrumentation.callActivityOnRestoreInstanceState(Instrumentation.java:1135)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2811)
... 11 more
Caused by: java.lang.ClassNotFoundException: my.app.package.a.ae
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:235)
at java.io.ObjectInputStream.resolveClass(ObjectInputStream.java:2590)
at java.io.ObjectInputStream.readNewClassDesc(ObjectInputStream.java:1846)
at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:826)
at java.io.ObjectInputStream.readNewObject(ObjectInputStream.java:2066)
at java.io.ObjectInputStream.readNonPrimitiveContent(ObjectInputStream.java:929)
at java.io.ObjectInputStream.readObject(ObjectInputStream.java:2285)
at java.io.ObjectInputStream.readObject(ObjectInputStream.java:2240)
at android.os.Parcel.readSerializable(Parcel.java:1945)
... 19 more
Caused by: java.lang.NoClassDefFoundError: my.app.package.a.ae
... 29 more
Caused by: java.lang.ClassNotFoundException: my.app.package.a.ae in loader dalvik.system.PathClassLoader[.]
at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
... 29 more
请注意,我使用的是proguard->这就是为什么“缺少”的类名是“a.ae”。
实际上,“a.ae”是proguard给类“MyObject”的名称,如下所示。
关于为什么会发生这种情况的任何想法?
我不认为这与proguard有关,因为如果这是由proguard类重命名引起的问题,它应该一直发生,我将能够自己重现这个问题。
它是否与将可序列化对象传递给 MyActivity 有关?
在“我的活动”中,我有
public void onCreate(Bundle savedInstanceState) {
myObj = (MyObject) getIntent().getSerializableExtra("nameOfMyObject");
//here I am trying to read myObj's properties and app seems to crash here
}
MyObject只是一个具有多种类型的类成员的实体,例如:
公共类MyObject实现Serializable {
/** Generated serialVersionUID */
static final long serialVersionUID = -267025879233327409L;
static final String CONSTANT1 = "xpto";
LinkedHashMap<String, Object> components;
ArrayList<String> prop1;
(...)
}
我开始我的活动是:
MyObject obj = new MyObj(stuff);
Intent intent;
intent = new Intent(CurrentActivity.this, MyActivity.class);
intent.putExtra("nameOfMyObject", obj);
CurrentActivity.this.startActivity(intent);
你认为这与对象的传递方式有关吗(作为可序列化的额外内容)?
如果我没有找到任何其他解决方案,我认为我会自己将对象“序列化”为字符串,然后额外传递字符串。对此,你怎么看?
编辑:我已尝试在模拟器和以下设备中重现此问题,但没有成功:
-摩托罗拉里程碑 2 安卓 2.2
-三星银河标签 安卓 2.2
-沃达丰 845 安卓 2.1
-HTC 塔图安卓 1.6
-Xperia X10 安卓 1.6
-Nexus One 安卓 2.2
-谷歌 G1 安卓 1.5
有什么新的想法吗?