NDK开发

本文介绍了在Android项目中遇到的构建失败问题,原因是同时使用了jniLibs和CMake导致了多个相同库的存在。解决方案包括在build.gradle中添加packagingOptions以指定优先选择的SO文件,或者更改jniLibs目录名称并更新CMakeLists.txt配置。此外,还提到了Windows与Linux文件格式不兼容的问题及其解决方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':app:mergeDebugNativeLibs'.
> A failure occurred while executing com.android.build.gradle.internal.tasks.MergeJavaResWorkAction
   > 2 files found with path 'lib/arm64-v8a/libswscale.so'.
     If you are using jniLibs and CMake IMPORTED targets, see
     https://developer.android.com/r/tools/jniLibs-vs-imported-targets

 

原因:

jniLibs和CMAKE混用,导致生成了两个so,系统不知道使用哪个so

方案一:在defaultConfig中加入packagingOptions选项,指定优先选择哪个

externalNativeBuild {
    cmake {
        cppFlags ''
    }
}

packagingOptions {
    pickFirst 'lib/arm64-v8a/libswscale.so'
    pickFirst 'lib/arm64-v8a/libavcodec.so'
    pickFirst 'lib/lib/arm64-v8a/libavutil.so'
    pickFirst 'lib/arm64-v8a/libavutil.so'
    pickFirst 'lib/arm64-v8a/libavformat.so'
    pickFirst 'lib/arm64-v8a/libavfilter.so'
    pickFirst 'lib/arm64-v8a/libswresample.so'
    pickFirst 'lib/arm64-v8a/libavdevice.so'
}

 

方案二:将jniLibs修改名称,如:jni,并在CMakeLists.txt中修改引用路径

 

 

报错:/bin/bash^M: bad interpreter: No such file or directory

原因:windows上编辑的文件在Linux上运行,格式不对

1.sed -i "s/\r//" filename 或sed -i "s/^M//" filename,直接将回车符替换为空字符串。

2.vim filename,编辑文件,执行“: set ff=unix”,将文件设置为unix格式,然后执行“:wq”,保存退出。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值