【问题标题】:ActiveAndroid NoClassDefFoundError exception on enum field枚举字段上的 ActiveAndroid NoClassDefFoundError 异常
【发布时间】:2017-07-11 12:16:03
【问题描述】:

它只在装有 Android 4.3 的 Galaxy Nexus 上发生过一次。 带有枚举字段的 Active Android 中是否存在一些已知问题? 谷歌没有帮助,我什至不确定在哪里看。

我必须提到我有 multiDexEnabled=true,这可能是 ActiveAndroid 在这个奇怪的地方搜索类的原因 (my_app_name-1.apk)

java.lang.NoClassDefFoundError: .../models/QuickAction$ActionType
at java.lang.Class.getDeclaredFields(Native Method)
at java.lang.Class.getDeclaredFields(Class.java:560)
at com.activeandroid.util.ReflectionUtils.getDeclaredColumnFields(ReflectionUtils.java:73)
at com.activeandroid.TableInfo.<init>(TableInfo.java:66)
at com.activeandroid.ModelInfo.loadModelFromMetaData(ModelInfo.java:101)
at com.activeandroid.ModelInfo.<init>(ModelInfo.java:61)
at com.activeandroid.Cache.initialize(Cache.java:66)
at com.activeandroid.ActiveAndroid.initialize(ActiveAndroid.java:44)
at com.activeandroid.ActiveAndroid.initialize(ActiveAndroid.java:34)
at com.activeandroid.ActiveAndroid.initialize(ActiveAndroid.java:30)
at com.activeandroid.app.Application.onCreate(Application.java:25)
at ...MyApplication.onCreate(MyApplication.java:12)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1007)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4444)
at android.app.ActivityThread.access$1300(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1316)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5103)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:525)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: Didn't find class "...models.QuickAction$ActionType" on path: DexPathList[[zip file "/data/app/...-1.apk"],nativeLibraryDirectories=[/data/app-lib/...-1, /vendor/lib, /system/lib]]
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:53)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
    ... 24 more

【问题讨论】:

  • 你在使用签名的 APK 吗?
  • 你在使用proguard吗,你有没有在你的应用程序中调用MultiDex.install(this);
  • 是的,应用已签名,我从 googleplay 控制台收到此崩溃报告
  • 不,我没有使用 proguard,至少我是这么认为的。这是我的 gradle 中的代码,默认代码 - proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'。不,我什至没有听说过 MultiDex.install(this);

标签: java android activeandroid


【解决方案1】:

根据MultiDex documentation,您需要从您的应用程序中调用MultiDex.install(this)

通过附加从应用程序 apk 加载的额外 dex 文件来修补应用程序上下文类加载器。

您可以通过扩展 MultiDexApplication 类来做到这一点:

public class MyApplication extends MultiDexApplication { ... }

或者,如果您有自己的自定义应用程序类已经扩展了其他内容,请直接调用 install

public class MyApplication extends SomeOtherApplication {
  @Override
  protected void attachBaseContext(Context base) {
     super.attachBaseContext(base);
     MultiDex.install(this);
  }
}

为什么我们只需要对 4.4 及以下版本执行此操作?如果我们 look at the docs again 我们可以看到 MultiDex 支持内置于 Android 5.0 (L) 及更高版本:

Android 5.0(API 级别 21)及更高版本使用名为 ART 的运行时,它本机支持从 APK 文件加载多个 DEX 文件。

确实,如果我们进入 MultiDex 支持库,我们可以看到如果设备 VM 被认为是“支持多 dex”,则它是无操作的:

public static void install(Context context) {
    Log.i("MultiDex", "install");
    if(IS_VM_MULTIDEX_CAPABLE) {
        Log.i("MultiDex", "VM has multidex support, MultiDex support library is disabled.");
    } else if(VERSION.SDK_INT < 4) {
        throw new RuntimeException("Multi dex installation failed. SDK " + VERSION.SDK_INT + " is unsupported. Min SDK version is " + 4 + ".");
    } else {
        // Set up multidex
        ...
    }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-08-19
    • 2019-05-26
    • 2020-02-13
    • 1970-01-01
    • 2015-01-17
    • 1970-01-01
    • 2018-10-21
    相关资源
    最近更新 更多