android - E/LoadedApk : Unable to instantiate appComponentFactory only on Android Q (API 29)

标签 android android-studio gradle android-multidex

我已经到处搜索了这个问题,但仍然没有解决方案。
gradle 有 minSdkVersion 21 和 targetSdkVersion 29
我只在 API 29 中遇到错误,然后应用程序没有加载并显示空白屏幕。当我看到 logcat 时,它会给出这样的错误:

E/LoadedApk: Unable to instantiate appComponentFactory
java.lang.ClassNotFoundException: Didn't find class "androidx.core.app.CoreComponentFactory" on path: DexPathList[[],nativeLibraryDirectories=[/data/app/com.packagename.appname-BxS7Zs-h0IWwJAVhbjx7aQ==/lib/x86, /data/app/com.packagename.appname-BxS7Zs-h0IWwJAVhbjx7aQ==/base.apk!/lib/x86, /system/lib, /system/product/lib]]
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:196)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
    at android.app.LoadedApk.createAppFactory(LoadedApk.java:256)
    at android.app.LoadedApk.updateApplicationInfo(LoadedApk.java:370)
    at android.app.ActivityThread.handleDispatchPackageBroadcast(ActivityThread.java:5951)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1941)
    at android.os.Handler.dispatchMessage(Handler.java:107)
    at android.os.Looper.loop(Looper.java:214)
    at com.android.server.SystemServer.run(SystemServer.java:541)
    at com.android.server.SystemServer.main(SystemServer.java:349)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:908)
我认为它似乎来自multidex,然后我尝试将以下代码添加到gradle app

multiDexKeepFile file('multidex-config.txt')

multiDexKeepProguard file('multidex-config.pro')


我的 multidex-config.txt
com/packagename/appname/androidx.class
我的 multidex-config.pro
-keep class androidx.core.app.CoreComponentFactory { *; }
我的 App 类扩展 MultiDexApplication
public class App extends MultiDexApplication {

    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);
        MultiDex.install(this);
    }
}
我的 list
<application
    android:name=".App"
    android:allowBackup="true"
    android:icon="@mipmap/ic_logo"
    android:label="@string/app_name"
    android:roundIcon="@mipmap/ic_logo"
    android:supportsRtl="true"
    android:theme="@style/main"
    android:usesCleartextTraffic="true"
    tools:ignore="GoogleAppIndexingWarning">
我的 gradle.properties
android.enableJetifier=true
android.useAndroidX=true
org.gradle.jvmargs=-Xmx1536m
我的毕业/应用
apply plugin: 'com.android.application'
apply plugin: 'com.google.gms.google-services'
apply plugin: 'io.fabric'

apply plugin: 'kotlin-android'

apply plugin: 'kotlin-android-extensions'

android {
    compileSdkVersion 29
    buildToolsVersion "29.0.3"
    defaultConfig {
        applicationId "com.packagename.appname"
        minSdkVersion 21
        targetSdkVersion 29
        versionCode 7
        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        debug {
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            multiDexKeepFile file('multidex-config.txt')
            multiDexKeepProguard file('multidex-config.pro')
            minifyEnabled true
        }
        release {
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            multiDexKeepFile file('multidex-config.txt')
            multiDexKeepProguard file('multidex-config.pro')
            minifyEnabled true
        }
    }
    compileOptions {
        targetCompatibility JavaVersion.VERSION_1_8
        sourceCompatibility JavaVersion.VERSION_1_8
    }
    kotlinOptions {
        jvmTarget = "1.8"
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    implementation 'androidx.appcompat:appcompat:1.1.0'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    implementation 'androidx.legacy:legacy-support-v4:1.0.0'
    implementation 'com.google.android.gms:play-services-maps:17.0.0'
    implementation 'com.google.android.libraries.places:places:2.2.0'
    testImplementation 'junit:junit:4.13'
    androidTestImplementation 'androidx.test.ext:junit:1.1.1'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
    implementation 'com.google.android.material:material:1.1.0'
    implementation 'androidx.cardview:cardview:1.0.0'

    implementation 'com.android.support:multidex:2.0.1'

    implementation 'com.github.vipulasri:timelineview:1.1.0'
    implementation 'de.hdodenhof:circleimageview:3.1.0'
    implementation 'com.yanzhenjie.zbar:camera:1.0.0'
    implementation 'androidx.percentlayout:percentlayout:1.0.0'

    implementation 'com.amitshekhar.android:android-networking:1.0.2'

    implementation 'com.google.firebase:firebase-core:17.2.2'
    implementation 'com.google.firebase:firebase-messaging:20.1.0'
    implementation 'com.crashlytics.sdk.android:crashlytics:2.10.1'

    implementation 'com.github.bumptech.glide:glide:4.11.0'
    annotationProcessor 'com.github.bumptech.glide:compiler:4.11.0'

    implementation 'com.github.kenglxn.QRGen:android:2.5.0'

    implementation 'com.facebook.android:facebook-android-sdk:4.36.0'

    implementation 'com.jsibbold:zoomage:1.2.0'

    implementation 'androidx.arch.core:core-common:2.1.0'
    implementation 'androidx.arch.core:core-runtime:2.1.0'
}
我真的需要一个解决方案。请帮助我,非常感谢!

最佳答案

错误指向使用androidx CoreComponentFactory类(使用 AndroidX),但您使用的是旧包 com.android.support:multidex
所以使用androidx依赖为:

implementation 'androidx.multidex:multidex:2.0.1'

代替
implementation 'com.android.support:multidex:2.0.1'

并确保使用 androidx在应用程序类中导入为
import android.content.Context;
import androidx.multidex.MultiDex;
import androidx.multidex.MultiDexApplication;

public class YourApp extends MultiDexApplication {

    @Override
    protected void attachBaseContext(Context base) {
        MultiDex.install(this);
        super.attachBaseContext(base);
    }
}

另外:在应用加载期间,android Q 使用 CoreComponentFactory内部实例,无论您是否在 list 中使用它,这都会导致问题。

另外,添加 multiDexEnabled truedefaultConfig{multiDexEnabled true }
更新:在 RCA 之后,componentfactory导入问题已通过 androidx 解决lib 导入,但版本 4.36.0 中的 facebook sdk 依赖项存在另一个问题已通过将版本降级到 4.35.0 来解决(或使用最新版本集成)并发布 here .

关于android - E/LoadedApk : Unable to instantiate appComponentFactory only on Android Q (API 29),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60472222/

相关文章:

Android Intent 的堆栈 - 登录屏幕和主菜单

android - 安装应用程序需要几分钟时间,并出现 dex2oat 警告

android - Android Studio:如何获取当前所选产品 flavor 的名称?

java - 为什么 Android Material Design 选项卡布局不起作用?

android - 使用 Linux 和命令行将 Android PhoneGap 应用程序转换为 iOS

android - 缺少 Content_main.xml

android - Firebase notification_key 发送通知

当将布局包含到协调 View 中时,android Studio 布局预览为空

java - 如何使 Java 代码从 XML 文件调用字符串(在 Android Studio 中)

java - 修改build.gradle以引用本地jar