2014-09-24 66 views
1

我有一个Android应用程序,它使用了大量的JAR并且达到了65K方法的限制。为了解决这个问题,我使用了支持multi-dex选项的Android Maven Plugin 4.0.0-rc.1。我能够生成多个dex文件的APK文件; classes.dex和classes2.dex。java.lang.UnsupportedOperationException:不支持类加载器 - Android多个dex问题

但是,当我在平板电脑上安装并运行此应用程序时,出现以下异常。

com.mmh.application.MiApplication: java.lang.UnsupportedOperationException: Class loader not supported 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4733) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.app.ActivityThread.access$1600(ActivityThread.java:175) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1368) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.os.Handler.dispatchMessage(Handler.java:102) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.os.Looper.loop(Looper.java:146) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.app.ActivityThread.main(ActivityThread.java:5602) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at java.lang.reflect.Method.invokeNative(Native Method) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at java.lang.reflect.Method.invoke(Method.java:515) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at dalvik.system.NativeStart.main(Native Method) 
09-24 20:29:52.672: E/AndroidRuntime(3810): Caused by: java.lang.UnsupportedOperationException: Class loader not supported 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at com.mmh.application.Dexter.loadAllDexes(Dexter.java:69) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at com.mmh.application.MiApplication.onCreate(MiApplication.java:292) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1013) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4730) 
09-24 20:29:52.672: E/AndroidRuntime(3810):  ... 10 more 

我使用的是在PR https://github.com/jayway/maven-android-plugin/pull/425给予相同的德克斯特类。

MiApplication的片段是如下 -

public class MiApplication extends Application { 
    public void onCreate() { 
     Dexter.loadAllDexes(this); 
     super.onCreate(); 
} 

我印它是使用加载德克斯特类的类加载器,它似乎它的使用PathClassLoader。如果它是从比DexClassLoader任何其他加载

09-24 20:29:52.672: I/c*.m*.a*.Dexter(3810): Dexter Classloader dalvik.system.PathClassLoader: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.miairline-3.apk"],nativeLibraryDirectories=[/data/app-lib/com.miairline-3, /vendor/lib, /system/lib]]] 

德克斯特类抛出“不支持的类加载器”异常。

如何确保从DexClassLoader加载Dexter类?以及如何解决这个“不受支持的类加载器”问题?

回答

0

我找到了这个问题的答案。这是我的错误。

而不是

localClassLoader instanceof BaseDexClassLoader 

我用了

localClassLoader instanceof DexClassLoader 

当我改变所有引用从DexClassLoader到BaseDexClassLoader,这个问题就走了,我能够在创建并加载多个DEX文件我应用。

0

该平板电脑上有哪个Android版本?如果这是ICS会很奇怪,因为我已经在ICS上测试过它,并且它工作正常。我还写了一些代码,可以在姜饼上工作,据我所知,PathClassLoader和DexClassLoader在GB和Honeycomb上有相同的源代码。 ICS进行了更改,德克斯特针对ICS进行了更改。 Dexter需要BaseDexClassLoader,它是ICS上PathClassLoader和DexClassLoader的基类。在ICS之前,这些类直接从ClassLoader继承。

检查项目: https://github.com/casidiablo/multidex/ 它看起来比我写代码更好的,我不知道,如果这个工程没有通过AMP创建修改魔女二次dexes但应该可以帮助您。

+0

该平板电脑是三星Galaxy Tab4和果冻豆(4.4.2)。我试着改变Dexter代码来使用PathClassLoader,但是它会抛出“找不到pathList字段”的异常。如果您看到,Dexter会检查类加载器是否是DexClassLoader的实例,而不是BaseDexClassLoader,因此我不确定它是如何用于PathClassLoader的。 – mmh 2014-09-27 05:25:47

+0

如果您不介意,可否请您分享代码的相关部分以及您的maindexList文件。 – mmh 2014-09-27 05:28:29