为什么 android.arch.navigation 导致程序类型已经存在:android.support.v4.os.ResultReceiver$1?

Why does android.arch.navigation cause Program type already present: android.support.v4.os.ResultReceiver$1?

我正在使用 Android Studio 版本

Android Studio 3.2 Canary 14
Build #AI-181.4668.68.32.4763614, built on May 4, 2018
JRE: 1.8.0_152-release-1136-b02 x86_64
JVM: OpenJDK 64-Bit Server VM by JetBrains s.r.o
Mac OS X 10.11.6

在调查新的架构导航组件时android.arch.navigation我遇到了这个构建失败。

AGPBI: {"kind":"error","text":"Program type already present: android.support.v4.os.ResultReceiver","sources":[{}],"tool":"D8"}
:app:transformDexArchiveWithExternalLibsDexMergerForDebug FAILED
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':app:transformDexArchiveWithExternalLibsDexMergerForDebug'.
> com.android.builder.dexing.DexArchiveMergerException: Error while merging dex archives: ...
...
  Program type already present: android.support.v4.os.ResultReceiver

我的应用 gradle 构建类似于:-

apply plugin: 'com.android.application'
apply plugin: "androidx.navigation.safeargs"

android {
    compileSdkVersion 'android-P'
    defaultConfig {
        applicationId "com.research.frager"
        minSdkVersion 19
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    def nav_version = "1.0.0-alpha01"

    implementation "android.arch.navigation:navigation-fragment:$nav_version"
    implementation "android.arch.navigation:navigation-ui:$nav_version"

    // optional - Test helpers
    androidTestImplementation "android.arch.navigation:navigation-testing:$nav_version"

    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'androidx.appcompat:appcompat:1.0.0-alpha1'

    implementation 'androidx.constraintlayout:constraintlayout:1.1.0'
    implementation 'androidx.lifecycle:lifecycle-extensions:2.0.0-alpha1'
    testImplementation 'junit:junit:4.12'

    androidTestImplementation 'androidx.test:runner:1.1.0-alpha2'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.0-alpha2'
}

和项目级别 gradle 构建:-

buildscript {

    repositories {
        google()
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.2.0-alpha14'
        classpath "android.arch.navigation:navigation-safe-args-gradle-plugin:1.0.0-alpha01"
    }
}

allprojects {
    repositories {
        google()
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

我已经尝试重构为 AndroidX,但是我收到一条消息,指出在项目中找不到任何用法,那么为什么这个 "v4" class 仍然被提及?

我一直在研究这个问题,我已经通过在将依赖项添加到库时排除支持包来解决这里的主要问题,这样做:

implementation("android.arch.navigation:navigation-fragment:$nav_version") {
  exclude group: 'com.android.support'
}

这将允许您 运行 该应用程序。但是,此工件使用的是支持工件而不是 androidx 工件。查看文档,我们可以看到 NavHostFragment 正在扩展支持。v4.Fragment https://developer.android.com/reference/androidx/navigation/fragment/NavHostFragment

所以,简而言之,据我所知,您有三个选项。第一个是删除 androidx 工件并使用最终取决于您的应用程序大小的支持工件。

第二种选择是删除导航库并返回处理导航的经典方式,我想这可能不适合您。

第三种选择是实现一个自己的导航主机,我不知道这会有多少工作量。

此回复将保持准确,直到 Google 发布库的 androidx 版本,我很惊讶他们还没有发布。

希望对您有所帮助。