关于build.gradle中的packagingOptions配置参数

本文一来带大家了解一下这个配置参数使用方法,二来说说这个配置参数会引起哪些问题。

使用方法

packagingOptions常见的设置项有exclude、pickFirst、doNotStrip、merge

1. exclude

过滤掉某些文件或者目录不添加到APK中,作用于APK,不能过滤aar和jar中的内容。

packagingOptions {
    exclude 'META-INF/**'
    exclude 'lib/arm64-v8a/libmediaplayer.so'
}

2. pickFirst

匹配到多个相同文件,只提取第一个,作用于APK,不能过滤aar和jar中的文件。

packagingOptions {
    pickFirst "lib/armeabi-v7a/libaaa.so"
    pickFirst "lib/armeabi-v7a/libbbb.so" 
}

3. doNotStrip

可以设置某些动态库不被优化压缩。

packagingOptions{
    doNotStrip "*/armeabi/*.so"
    doNotStrip "*/armeabi-v7a/*.so"
}

4. merge

将匹配的文件都添加到APK中,和pickFirst有些相反,会合并所有文件。

packagingOptions {
    merge '**/LICENSE.txt'
    merge '**/NOTICE.txt'
}

参考文章

引入库少配置该参数出现的问题

问题

引入库后打正式包无法安装,报Failure
[INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION: Failed to parse /data/app/vmdl1293559276.tmp/base.apk: AndroidManifest.xml]

解决

android {
 packagingOptions {
 exclude 'AndroidManifest.xml'
 ...
 }
 ...
 }

最近公司接入个ts的sdk出现了上述问题,分享给大家少踩点坑

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Gradle是一种构建工具,用于自动化项目构建过程。build.gradle是Gradle项目的配置文件,用于定义和配置项目构建的任务和属性。 在build.gradle文件,我们可以定义项目的源代码目录、依赖项、编译选项、测试配置以及其他构建相关的任务。以下是一些常见的配置选项和用法: 1. 定义源代码目录:在build.gradle文件,我们可以通过设置sourceSets属性来定义项目的源代码目录。例如,我们可以使用以下代码将源代码目录设置为"src/main/java"和"src/test/java": sourceSets { main { java.srcDirs = ['src/main/java'] } test { java.srcDirs = ['src/test/java'] } } 2. 添加依赖项:通过dependencies块,我们可以添加项目的依赖项。可以使用不同的配置来指定不同的依赖,如compile、testCompile、implementation等。例如,我们可以使用以下代码添加一个编译时依赖库: dependencies { implementation 'com.google.guava:guava:30.0-jre' } 3. 自定义任务:使用task块,我们可以定义自定义构建任务。例如,我们可以使用以下代码定义一个自定义任务,该任务执行打印一条消息的操作: task printMessage { doLast { println 'Hello, Gradle!' } } 4. 应用插件:使用apply插件块,我们可以应用Gradle插件来扩展构建功能。例如,我们可以使用以下代码应用Java插件: apply plugin: 'java' 5. 配置编译选项:我们可以使用compileOptions块来配置Java编译选项,如源代码和目标版本。例如,我们可以使用以下代码将Java编译选项设置为1.8: compileOptions { sourceCompatibility = 1.8 targetCompatibility = 1.8 } 以上是一些常见的Gradle build.gradle配置选项和用法。通过在build.gradle配置这些选项,我们可以自定义和控制项目的构建过程,以满足特定的需求和要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值