NDKBuild 失败

Posted

技术标签:

【中文标题】NDKBuild 失败【英文标题】:NDKBuild Failure 【发布时间】:2015-06-26 15:37:48 【问题描述】:

我无法让我的 NDK 在 android Studio 中正确编译。每当我尝试运行编译时,都会出现以下错误。

错误:任务 ':app:ndkBuild' 执行失败。 启动进程 'command 'ndk-build.cmd'' 时出现问题

我有以下设置

而我的 build.gradle 文件如下。

import org.apache.tools.ant.taskdefs.condition.Os

apply plugin: 'com.android.application'

android 
    compileSdkVersion 21
    buildToolsVersion "21.1.2"

    defaultConfig 
        applicationId "edu.uky.cs.www.diagramaphone"
        minSdkVersion 14
        targetSdkVersion 21
        versionCode 1
        versionName "1.0"

        sourceSets.main
            jniLibs.srcDir 'src/main/libs'
            jni.srcDirs = [] //disable automatic ndk-build call
        
        project.ext.versionCodes = ['armeabi':1, 'armeabi-v7a':2, 'arm64-v8a':3, 'mips':5, 'mips64':6, 'x86':8, 'x86_64':9] //versionCode digit for each supported ABI, with 64bit>32bit and x86>armeabi-*
        android.applicationVariants.all  variant ->
            // assign different version code for each output
            variant.outputs.each  output ->
                output.versionCodeOverride =
                        project.ext.versionCodes.get(output.getFilter(com.android.build.OutputFile.ABI), 0) * 1000000 + defaultConfig.versionCode
            
        
        // call regular ndk-build(.cmd) script from app directory
        task ndkBuild(type: Exec) 
            if (Os.isFamily(Os.FAMILY_WINDOWS)) 
                commandLine 'ndk-build.cmd', '-C', file('src/main').absolutePath
             else 
                commandLine 'ndk-build', '-C', file('src/main').absolutePath
            
        
        tasks.withType(JavaCompile) 
            compileTask -> compileTask.dependsOn ndkBuild
        
        //ndk 
          //  moduleName "shape-detect"
            //cFlags "-DANDROID_NDK -D_DEBUG DNULL=0" // Define some macros
            //ldLibs "EGL", "GLESv3", "dl", "log"         // Link with these libraries!
            //stl "stlport_shared"                        // Use shared stlport library
        //

    
    buildTypes 
        release 
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        
    


dependencies 
    compile fileTree(include: ['*.jar'], dir: 'libs')
    compile 'com.android.support:appcompat-v7:21.0.3'
    compile project(':libraries:tess-two')
    compile project(':libraries:opencv')

在这一点上,我不知道可能出了什么问题。我已经按照几个教程尝试设置 NDK 以使其正常工作,但我不断收到上面显示的错误。这里的任何人都可以提供一些关于我需要做什么才能让 NDK 编译的反馈吗?

编辑:这是发生的全部消息。

Information:Gradle tasks [:app:assembleDebug]
:app:preBuild UP-TO-DATE
:app:preDebugBuild UP-TO-DATE
:app:compileDebugNdk UP-TO-DATE
:app:checkDebugManifest
:app:preReleaseBuild UP-TO-DATE
:libraries:opencv:compileLint
:libraries:opencv:copyReleaseLint UP-TO-DATE
:libraries:opencv:mergeReleaseProguardFiles UP-TO-DATE
:libraries:opencv:preBuild UP-TO-DATE
:libraries:opencv:preReleaseBuild UP-TO-DATE
:libraries:opencv:checkReleaseManifest
:libraries:opencv:prepareReleaseDependencies
:libraries:opencv:compileReleaseAidl UP-TO-DATE
:libraries:opencv:compileReleaseRenderscript UP-TO-DATE
:libraries:opencv:generateReleaseBuildConfig UP-TO-DATE
:libraries:opencv:generateReleaseAssets UP-TO-DATE
:libraries:opencv:mergeReleaseAssets UP-TO-DATE
:libraries:opencv:generateReleaseResValues UP-TO-DATE
:libraries:opencv:generateReleaseResources UP-TO-DATE
:libraries:opencv:packageReleaseResources UP-TO-DATE
:libraries:opencv:processReleaseManifest UP-TO-DATE
:libraries:opencv:processReleaseResources UP-TO-DATE
:libraries:opencv:generateReleaseSources UP-TO-DATE
:libraries:opencv:compileReleaseJava UP-TO-DATE
:libraries:opencv:processReleaseJavaRes UP-TO-DATE
:libraries:opencv:packageReleaseJar UP-TO-DATE
:libraries:opencv:compileReleaseNdk UP-TO-DATE
:libraries:opencv:packageReleaseJniLibs UP-TO-DATE
:libraries:opencv:packageReleaseLocalJar UP-TO-DATE
:libraries:opencv:packageReleaseRenderscript UP-TO-DATE
:libraries:opencv:bundleRelease UP-TO-DATE
:libraries:tess-two:compileLint
:libraries:tess-two:copyReleaseLint UP-TO-DATE
:libraries:tess-two:mergeReleaseProguardFiles UP-TO-DATE
:libraries:tess-two:preBuild UP-TO-DATE
:libraries:tess-two:preReleaseBuild UP-TO-DATE
:libraries:tess-two:checkReleaseManifest
:libraries:tess-two:prepareReleaseDependencies
:libraries:tess-two:compileReleaseAidl UP-TO-DATE
:libraries:tess-two:compileReleaseRenderscript UP-TO-DATE
:libraries:tess-two:generateReleaseBuildConfig UP-TO-DATE
:libraries:tess-two:generateReleaseAssets UP-TO-DATE
:libraries:tess-two:mergeReleaseAssets UP-TO-DATE
:libraries:tess-two:generateReleaseResValues UP-TO-DATE
:libraries:tess-two:generateReleaseResources UP-TO-DATE
:libraries:tess-two:packageReleaseResources UP-TO-DATE
:libraries:tess-two:processReleaseManifest UP-TO-DATE
:libraries:tess-two:processReleaseResources UP-TO-DATE
:libraries:tess-two:generateReleaseSources UP-TO-DATE
:libraries:tess-two:compileReleaseJava UP-TO-DATE
:libraries:tess-two:processReleaseJavaRes UP-TO-DATE
:libraries:tess-two:packageReleaseJar UP-TO-DATE
:libraries:tess-two:compileReleaseNdk UP-TO-DATE
:libraries:tess-two:packageReleaseJniLibs UP-TO-DATE
:libraries:tess-two:packageReleaseLocalJar UP-TO-DATE
:libraries:tess-two:packageReleaseRenderscript UP-TO-DATE
:libraries:tess-two:bundleRelease UP-TO-DATE
:app:prepareComAndroidSupportAppcompatV72103Library UP-TO-DATE
:app:prepareComAndroidSupportSupportV42103Library UP-TO-DATE
:app:prepareDiagramaphoneLibrariesOpencvUnspecifiedLibrary UP-TO-DATE
:app:prepareDiagramaphoneLibrariesTessTwoUnspecifiedLibrary UP-TO-DATE
:app:prepareDebugDependencies
:app:compileDebugAidl UP-TO-DATE
:app:compileDebugRenderscript UP-TO-DATE
:app:generateDebugBuildConfig UP-TO-DATE
:app:generateDebugAssets UP-TO-DATE
:app:mergeDebugAssets UP-TO-DATE
:app:generateDebugResValues UP-TO-DATE
:app:generateDebugResources UP-TO-DATE
:app:mergeDebugResources UP-TO-DATE
:app:processDebugManifest UP-TO-DATE
:app:processDebugResources UP-TO-DATE
:app:generateDebugSources UP-TO-DATE
:app:ndkBuild FAILED
Error:Execution failed for task ':app:ndkBuild'.
> A problem occurred starting process 'command 'ndk-build.cmd''
Information:BUILD FAILED
Information:Total time: 2.226 secs
Information:1 error
Information:0 warnings
Information:See complete output in console

【问题讨论】:

抱歉,您的回答具有误导性。 -Cndk-build.cmd 的正确参数形式。尝试将 NDK 根目录添加到您的 PATH 如何确认我的 ndk 设置正确?我将再次编辑我的帖子以显示我目前拥有的内容,理想情况下,错误是我错过的一些小问题 NDK 设置仅用于解压缩存档,并可能将生成的目录添加到 PATH。一个好的检查是打开命令提示符并尝试在该窗口中运行ndk-build.cmd。实际上,有一个重要的规则:不要使用带空格的路径,例如C:\Program Files 嗨,我在 Android Studio Ubuntu 中遇到了同样的问题,我正在使用 ubuntu 并且在 build.gradle OSFamily 中设置为 windows。如何解决这个问题?请尽快帮助我。提前致谢. 【参考方案1】:

我遇到了这种问题。首先,您必须在您的应用程序的local.properties 中提供您的 NDK 路径。

例如ndk.dir=/home/user/bin/android_ndk/android-ndk-r10e

然后在我的build.gradle 文件中,我有类似这样的调用 ndk build 命令。

commandLine 'ndk-build', '-C', file('src/main/jni').absolutePath

我把它改成

commandLine '/home/user/bin/android_ndk/android-ndk-r10e/ndk-build', '-C', file('src/main/jni').absolutePath

我给出了 NDK 构建的完整路径。希望对你有帮助。

【讨论】:

最好使用来自local.properties 的值而不是硬编码路径:def ndkDir = plugins.getPlugin('com.android.library').sdkHandler.ndkFolder。然后命令行会是这样的:commandLine '$ndkDir/ndk-build', '-C', file('src/main/jni').absolutePath 如果你在local.properties 中定义了这个ndk.dir,为什么要给出完整路径? 在本地属性中我有到 android-ndk-r10e 的路径,在 build.gradle 我有到 ndk_build 的路径。我同意我可以使用本地属性中的 ndk.dir 而不是 home/user/bin/android_ndk/android-ndk-r10e。 对这个答案表示反对。此外,如果您使用的是 Windows 并遇到相同的错误,请将接受的答案行 '/home/user/bin/android_ndk/android-ndk-r10e/ndk-build' 编辑为 '/home/user/bin/android_ndk/android-ndk-r10e/ndk-build.cmd' 改了之后还是报错..怎么解决?【参考方案2】:

在android studio中,文件->项目结构-> SDK位置, 为您的计算机设置 Android NDK 位置。

谢谢!

【讨论】:

Android Studio 现在包含一个自动下载和设置 NDK 的选项。【参考方案3】:

试试这个

commandLine'E:\\Android\\ndk\\ndkbuild.cmd','-C',file('src/main/jni').absolutePath

将 (E:\\Android\\ndk\\) 替换为您的 ndk 路径。

【讨论】:

在local.properties ndk.dir=E:\\Android\\ndk中添加ndk路径【参考方案4】:

对于 android studio 2.3.3 来说很容易。只需按照文件-> 项目结构-> android NDK 位置-> 单击下载按钮。安装ndk后解决我的问题。

【讨论】:

这应该是公认的答案!所有其他人都只是黑客【参考方案5】:

以防万一它对其他人有帮助:

在环境变量中提供 NDK 路径(ndkBuild.cmd 所在的父文件夹)也可以解决问题。

或者,如果您使用的是 Linux,则可以遵循 @Hayk 的答案,或者在 Windows 上遵循 @Nooh 的答案。

我的观察:

因为,如果我将直接 NDK 路径有时在 Android Studio 中解决了我的问题,但它再次无法构建并抛出错误,然后我将路径放入环境变量中,项目构建成功。

在这种情况下,对于 Windows,必须放 *

ndk-build.cmd

* 并且仅适用于 Linux 环境 *

ndk 构建

*

【讨论】:

【参考方案6】:

    首先,您必须检查项目中的 local.properties 文件。在 local.properties 检查 ndk 路径。看起来像这样 ndk.dir=D:\\sdk\\ndk-bundle

    现在转到 build.gradle(Module library) 并找到 getNdkPath()。 它将返回连接 ndk-build

    的 ndk 路径位置

    更改 ndk-build --> ndk-build.cmd。它看起来像这样:

希望对你有帮助!

【讨论】:

【参考方案7】:

将 ndk 路径(C:\android-ndk-r10e)添加到环境变量(系统变量)中的路径变量值中,这样我的“路径”变量就这样了

设置 --> 系统 --> 高级系统设置 --> 系统变量

然后打开命令窗口(cmd)。使用 cd 命令输入项目文件夹的位置并编写“ndk-build”,然后按 Enter。

【讨论】:

【参考方案8】:

接受的答案是可以的,但是从android tools gradle plugin 2.3开始就不行了:No sdkHandler field in LibraryPlugin after updating to build tools 2.3.0,所以你需要使用project.android.ndkDirectory.absolutePath这个变量,即:

task ndkBuild(type: Exec) 
    commandLine project.android.ndkDirectory.absolutePath + '/ndk-build', '-C', file('src/main/jni/').absolutePath

您也可以直接从 local.properties 读取 ndk.dir:https://***.com/a/32649204/1028256

【讨论】:

【参考方案9】:

看看下面的这些链接。

你必须知道NDK通常所在的路径

库/Android/sdk/ndk/

https://developer.android.com/studio/releases?utm_source=android-studio#4-0-0-ndk-dir

https://developer.android.com/studio/projects/install-ndk

https://wiki.appcelerator.org/display/guides2/Installing+the+Android+NDK

【讨论】:

以上是关于NDKBuild 失败的主要内容,如果未能解决你的问题,请参考以下文章

gradle + ndkbuild + android studio 2.2 如何设置支持的 ABI?

Android Ndkbuild与Cmake

AS使用ndkbuild创建cpp工程记录

Android Gradle 插件ProductFlavor 配置 ( AppExtension#externalNativeBuild 配置 | cmake 配置 | ndkBuild 配置 )

Android Gradle 插件ProductFlavor 配置 ( ProductFlavor#externalNativeBuild配置 | cmake 配置 | ndkBuild 配置 )

kbuild-(directory)