【问题标题】:Application running on Marshmallow, but not on Jellybean应用程序在 Marshmallow 上运行,但不在 Jellybean 上
【发布时间】:2017-01-19 14:10:26
【问题描述】:

我是安卓开发新手。我在android中开发了一个应用程序并设置了我的minSdkVersion 16targetSdkVersion 16,但它仍然没有在果冻豆上运行,但在棉花糖上运行良好。

我找不到错误。

我的 gradle 文件是:

apply plugin: 'com.android.application'

android {
compileSdkVersion 23
buildToolsVersion "24.0.3"
defaultConfig {
    applicationId "com.theakshaynaik.pocketambulance"
    minSdkVersion 16
    targetSdkVersion 16
    versionCode 1
    versionName "1.0"
    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    multiDexEnabled true
}
buildTypes {
    release {
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    }
  }
}

dependencies {
compile fileTree(include: ['*.jar'], dir: 'libs')
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
    exclude group: 'com.android.support', module: 'support-annotations'
})
compile files('libs/httpclient-4.0.3.jar')
compile 'com.android.support:appcompat-v7:23.4.0'
compile 'com.firebaseui:firebase-ui:0.5.1'
compile 'com.google.firebase:firebase-storage:10.0.1'
compile 'com.google.firebase:firebase-database:10.0.1'
compile 'com.google.android.gms:play-services:10.0.1'
compile 'com.android.support:multidex:1.0.0'
testCompile 'junit:junit:4.12'
}
apply plugin: 'com.google.gms.google-services'

我的日志是:

E/AndroidRuntime: FATAL EXCEPTION: main
              java.lang.RuntimeException: Unable to get provider com.google.firebase.provider.FirebaseInitProvider: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/com.theakshaynaik.pocketambulance-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.theakshaynaik.pocketambulance-1, /vendor/lib, /system/lib]]
                  at android.app.ActivityThread.installProvider(ActivityThread.java:4915)
                  at android.app.ActivityThread.installContentProviders(ActivityThread.java:4518)
                  at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4458)
                  at android.app.ActivityThread.access$1300(ActivityThread.java:144)
                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1319)
                  at android.os.Handler.dispatchMessage(Handler.java:99)
                  at android.os.Looper.loop(Looper.java:137)
                  at android.app.ActivityThread.main(ActivityThread.java:5136)
                  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 "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/com.theakshaynaik.pocketambulance-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.theakshaynaik.pocketambulance-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)
                  at android.app.ActivityThread.installProvider(ActivityThread.java:4900)
                  at android.app.ActivityThread.installContentProviders(ActivityThread.java:4518) 
                  at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4458) 
                  at android.app.ActivityThread.access$1300(ActivityThread.java:144) 
                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1319) 
                  at android.os.Handler.dispatchMessage(Handler.java:99) 
                  at android.os.Looper.loop(Looper.java:137) 
                  at android.app.ActivityThread.main(ActivityThread.java:5136) 
                  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) 

【问题讨论】:

  • 你能告诉我们错误吗?出现问题的 StackTrace 以及导致应用崩溃的代码。
  • 确保您的设备已更新 google play 服务,即 Google Play Services 9.0+,如果您在应用中使用 firebase,则需要此服务。

标签: android build.gradle android-6.0-marshmallow android-4.2-jelly-bean dex


【解决方案1】:

您似乎已达到 64K 方法限制,需要启用 multidex。 Android 5.0 以下使用 Dalvik,默认只支持 64K 方法(包括库),Android 5.0 及以上使用 ART,默认支持超过 64K 方法。您可以在 Android 开发者网站上阅读有关 multidex here 的所有信息。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-01-14
    • 1970-01-01
    • 2017-09-04
    • 1970-01-01
    • 2019-03-12
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多