调用readObject时出现类未找到异常

时间:2015-08-29 23:25:39

标签: classnotfoundexception google-play-games objectinputstream

我正在尝试在我的应用中使用Google Play游戏服务来实现回合制多人游戏。不幸的是,我在尝试加载Google Play Match中保存的数据时遇到了问题。

这是我的代码摘录:

ByteArrayInputStream bis = new ByteArrayInputStream(match.getData());
ObjectInputStream in = new ObjectInputStream(bis);
Object o = in.readObject();
matchData = (MatchData) o;

以下是我得到的例外情况:

08-29 19:11:02.620  20712-20712/com.cor31.letterbetter E/MainMenu﹕ Error loading match data.
    java.lang.ClassNotFoundException: com.cor31.letterbetter.h
            at java.lang.Class.classForName(Native Method)
            at java.lang.Class.forName(Class.java:251)
            at java.io.ObjectInputStream.resolveClass(ObjectInputStream.java:2262)
            at java.io.ObjectInputStream.readNewClassDesc(ObjectInputStream.java:1638)
            at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:658)
            at java.io.ObjectInputStream.readNewObject(ObjectInputStream.java:1781)
            at java.io.ObjectInputStream.readNonPrimitiveContent(ObjectInputStream.java:762)
            at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1981)
            at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1938)
            at com.cor31.letterbetter.Constants.loadMatchData(Constants.java:134)
            at com.cor31.letterbetter.MainMenuActivity.onActivityResult(MainMenuActivity.java:483)
            at android.app.Activity.dispatchActivityResult(Activity.java:5643)
            at android.app.ActivityThread.deliverResults(ActivityThread.java:3576)
            at android.app.ActivityThread.handleSendResult(ActivityThread.java:3623)
            at android.app.ActivityThread.access$1400(ActivityThread.java:169)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1328)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:146)
            at android.app.ActivityThread.main(ActivityThread.java:5487)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.NoClassDefFoundError: com/cor31/letterbetter/h
            at java.lang.Class.classForName(Native Method)
            at java.lang.Class.forName(Class.java:251)
            at java.io.ObjectInputStream.resolveClass(ObjectInputStream.java:2262)
            at java.io.ObjectInputStream.readNewClassDesc(ObjectInputStream.java:1638)
            at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:658)
            at java.io.ObjectInputStream.readNewObject(ObjectInputStream.java:1781)
            at java.io.ObjectInputStream.readNonPrimitiveContent(ObjectInputStream.java:762)
            at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1981)
            at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1938)
            at com.cor31.letterbetter.Constants.loadMatchData(Constants.java:134)
            at com.cor31.letterbetter.MainMenuActivity.onActivityResult(MainMenuActivity.java:483)
            at android.app.Activity.dispatchActivityResult(Activity.java:5643)
            at android.app.ActivityThread.deliverResults(ActivityThread.java:3576)
            at android.app.ActivityThread.handleSendResult(ActivityThread.java:3623)
            at android.app.ActivityThread.access$1400(ActivityThread.java:169)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1328)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:146)
            at android.app.ActivityThread.main(ActivityThread.java:5487)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "com.cor31.letterbetter.h" on path: DexPathList[[zip file "/data/app/com.cor31.letterbetter-183.apk"],nativeLibraryDirectories=[/data/app-lib/com.cor31.letterbetter-183, /vendor/lib, /system/lib]]
            at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:67)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
            at java.lang.Class.classForName(Native Method)
            at java.lang.Class.forName(Class.java:251)
            at java.io.ObjectInputStream.resolveClass(ObjectInputStream.java:2262)
            at java.io.ObjectInputStream.readNewClassDesc(ObjectInputStream.java:1638)
            at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:658)
            at java.io.ObjectInputStream.readNewObject(ObjectInputStream.java:1781)
            at java.io.ObjectInputStream.readNonPrimitiveContent(ObjectInputStream.java:762)
            at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1981)
            at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1938)
            at com.cor31.letterbetter.Constants.loadMatchData(Constants.java:134)
            at com.cor31.letterbetter.MainMenuActivity.onActivityResult(MainMenuActivity.java:483)
            at android.app.Activity.dispatchActivityResult(Activity.java:5643)
            at android.app.ActivityThread.deliverResults(ActivityThread.java:3576)
            at android.app.ActivityThread.handleSendResult(ActivityThread.java:3623)
            at android.app.ActivityThread.access$1400(ActivityThread.java:169)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1328)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:146)
            at android.app.ActivityThread.main(ActivityThread.java:5487)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at     com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
            at dalvik.system.NativeStart.main(Native Method)

我的项目中没有'h'类,我不知道为什么在readObject期间搜索这个类。谁能解释我做错了什么?感谢。

0 个答案:

没有答案
相关问题