我有一个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类?以及如何解决这个“不受支持的类加载器”问题?
该平板电脑是三星Galaxy Tab4和果冻豆(4.4.2)。我试着改变Dexter代码来使用PathClassLoader,但是它会抛出“找不到pathList字段”的异常。如果您看到,Dexter会检查类加载器是否是DexClassLoader的实例,而不是BaseDexClassLoader,因此我不确定它是如何用于PathClassLoader的。 – mmh 2014-09-27 05:25:47
如果您不介意,可否请您分享代码的相关部分以及您的maindexList文件。 – mmh 2014-09-27 05:28:29