Gradle报错:No matching variant of project

前言

在新建一个项目时buildTypes默认有releasedebug两种,我们可以选择其中一种进行编译。

但是如果我们在build.gradle中再新增一种类型,例如qa时,此时会报错如下:

预备知识

首先我们要知道buildTypes是干嘛的?

它能够为你提供多种编译选择,我们可以在buildTypes中定义变量、配置混淆文件、配置签名文件等。最后生成BuildConfig.java文件。 例如:

java 复制代码
buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
            signingConfig signingConfigs.release
            buildConfigField "String", "VALUE", "\"XXXXXX\""
        }
}

其中buildConfigField 可以在最后生成的BuildConfig.java文件中生成一个静态变量。这是用处非常大的,就比如debug环境和release环境的请求地址可能不同,就可以通过这个进行定义,避免打包的时候忘记修改地址等问题。

在项目中每个moudle都有对应的build.gradle文件,所以每个moudle都可以生成一个BuildConfig.java

产生原因

当我们有多模块时,app模块选择了qa的type进行编译,此时依赖了moudle1,当它编译时,由于他没有声明qa这个buildTypes,编译器不知道如何生成对应的buildConfig文件。此时就会报错。

解决办法

方法一:

在moudel1的build.gradle文件下也加上qa的buildTypes,这样编译器就能找到如何生成文件了。但是当app依赖的模块过多的时候,就要一个模块一个模块的增加类型,这样比较麻烦。

方法二:

在app的build.gradle通过matchingFallbacks关键词,对该类型进行一个补充说明,意思是如果没有找到这个type,那么可以用配置的参数继续编译。举个例子就明白了

java 复制代码
 //app下的build.gradle
 buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
        qa {
            matchingFallbacks = ['release']
            buildConfigField "String", "VALUE", "\"app buildTypes 类型为qa\""
        }
    }
    
//moudle1下的build.gradle
buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
            buildConfigField "String", "VALUE", "\"虽然app用的是qa,但是我moudle找不到,所以用release\""
        }
    }

这里的qa通过matchingFallbacks 定义了一个release类型,所以当我们moudle1在编译时,如果找不到声明的qa type,就会使用release

最后app下的BuildConfig.java如下:

moudle1下的BuildConfig.java如下

相关推荐
黄林晴11 小时前
Android 17 Beta 2,隐私这把锁又拧紧了
android
Kapaseker11 小时前
研究表明,开发者对Kotlin集合的了解不到 20%
android·kotlin
bqliang12 小时前
Compose 媒体查询 (Media Query API) 🖱️👇🕹️
android·android jetpack
程序员陆业聪20 小时前
Android 平台 AI Agent 技术架构深度解析
android·人工智能
BD_Marathon1 天前
工厂方法模式
android·java·工厂方法模式
王码码20351 天前
Flutter for OpenHarmony:socket_io_client 实时通信的事实标准(Node.js 后端的最佳拍档) 深度解析与鸿蒙适配指南
android·flutter·ui·华为·node.js·harmonyos
勇气要爆发1 天前
吴恩达《LangChain LLM 应用开发精读笔记》2-Models, Prompts and Parsers 模型、提示和解析器
android·笔记·langchain
Railshiqian1 天前
给android源码下的模拟器添加两个后排屏的修改
android·开发语言·javascript
恋猫de小郭1 天前
Flutter 的真正价值是什么?深度解析再结合鸿蒙,告诉你 Flutter 的真正优势
android·前端·flutter
Ehtan_Zheng1 天前
我们如何在不减少功能的前提下,将安卓应用体积缩减 60%
android