【发布时间】:2016-11-11 11:01:07
【问题描述】:
这似乎是 Stack Overflow 中提出的最高问题之一,但即使在尝试了 10 多个问题中的 20 多个解决方案并参考了 Android Docs 之后,我的问题仍然没有解决。
LogCat:
FATAL EXCEPTION: main
Process: com.some.app, PID: 22838
java.lang.RuntimeException: Unable to instantiate application com.some.app.utils.Application: java.lang.ClassNotFoundException: Didn't find class "com.some.app.utils.Application" on path: DexPathList[[zip file "/data/app/com.some.app-1/base.apk"],nativeLibraryDirectories=[/data/app/com.some.app-1/lib/x86_64, /vendor/lib64, /system/lib64]]
at android.app.LoadedApk.makeApplication(LoadedApk.java:563)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4526)
at android.app.ActivityThread.access$1500(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1364)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.some.app.utils.Application" on path: DexPathList[[zip file "/data/app/com.some.app-1/base.apk"],nativeLibraryDirectories=[/data/app/com.some.app-1/lib/x86_64, /vendor/lib64, /system/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at android.app.Instrumentation.newApplication(Instrumentation.java:980)
at android.app.LoadedApk.makeApplication(LoadedApk.java:558)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4526)
at android.app.ActivityThread.access$1500(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1364)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
Suppressed: java.lang.ClassNotFoundException: com.some.app.utils.Application
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 13 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available
问题
1. 应用在摩托罗拉、三星 S6、三星 S7 等非 x86 设备上运行良好
2. 应用在 x86 架构设备上抛出该错误。
我到目前为止所尝试的
1. 我在 Manifest、packages 等中交叉检查了包名。
2. 为清单中的android:name 属性提供完整和部分包名称。
3. 尝试将Application 类从utils 包移动到主包。
背景
1. 安装 Android Studio - sudo apt-get install libc6:i386 libncurses5:i386 libstdc++6:i386 lib32z1 lib32bz2-1.0 时,除了 lib32bz2-1.0 外,一切正常,但到目前为止没有任何问题。 (之前从未尝试在 x86 设备上安装该应用程序)
2. 编译SDK版本 - 25
3. BuildToolsVersion - 25.0.0
4. Gradle 版本 - 2.2.2
工作环境
1. Ubuntu 16.04
2. 更新了 JAVA 8
3.Android Studio 2.2.2
编辑: 我认为可能导致问题的部分 gradle(应用程序)
packagingOptions {
exclude 'META-INF/NOTICE' // will not include NOTICE file
exclude 'META-INF/LICENSE' // will not include LICENSE file
exclude 'META-INF/notice'
exclude 'META-INF/notice.txt'
exclude 'META-INF/license'
exclude 'META-INF/license.txt'
}
sourceSets {
main {
java.srcDirs = ['src/main/java']
}
robolectric {
java.srcDir file('src/test/java/')
}
}
附:多次检查清单,似乎没有问题。在任何 Android 文档中也找不到任何可能导致此异常的原因。
更新:参考this answer 启用即时运行后不会导致问题。但是通过debug.apk 安装应用程序会出现同样的问题。
【问题讨论】:
-
你启用了multidex吗?
-
是 @AndroidFanatic,multidex 已启用,proguard 已关闭。
-
我们可以看看你的 build.gradle 文件吗?
-
build.gradle 的哪一部分?以及项目模块或应用程序模块? @SergeyNikitin
-
flavorDimensions 和 productFlavors @MohammedAtif
标签: java android android-studio x86