【问题标题】:How to Solve "Android/Sdk/ndk-bundle/ndk-build.cmd" finished with non-zero exit value 2 / exit value -1如何解决“Android/Sdk/ndk-bundle/ndk-build.cmd”以非零退出值 2 / 退出值 -1 结束
【发布时间】:2018-12-16 17:09:04
【问题描述】:

我正在使用最新版本的 ndk (18.1)。每当我尝试编译我的代码时,它都会显示任务':app:ndkBuild'的执行失败

我尝试了 2 个不同版本的 ndk (18.1) 和 (14.1),两者都显示几乎相同的错误,而唯一的区别是;

  • ndk (18.1) 显示 退出值 2
  • ndk (14.1) 显示 退出值 -1

jni 路径:

Build.Gradle:

apply plugin: 'com.android.application'

android {
compileSdkVersion 28
defaultConfig {
    applicationId "com.fyp.major.fyp1"
    minSdkVersion 21
    targetSdkVersion 28
    versionCode 1
    versionName "1.0"
    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}

sourceSets.main {
    jni.srcDirs = []  //disable automatic ndk-build call
}

task ndkBuild(type: Exec, description: 'Compile JNI source via NDK') {
    commandLine "C:/Users/MaJoR/AppData/Local/Android/Sdk/ndk-bundle/ndk-build.cmd",
            'NDK_PROJECT_PATH=build/intermediates/ndk',
            'NDK_LIBS_OUT=src/main/jniLibs',
            'APP_BUILD_SCRIPT=src/main/jni/Android.mk',
            'NDK_APPLICATION_MK=src/main/jni/Application.mk'
}
tasks.withType(JavaCompile) {
    compileTask -> compileTask.dependsOn ndkBuild
}

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

dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:28.0.0-alpha1'
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
implementation project(':openCVLibrary344')
}

ANDROID.mk

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

#opencv
OPENCVROOT:= C:\OpenCV-3.4.0-android-sdk
OPENCV_CAMERA_MODULES:=on
OPENCV_INSTALL_MODULES:=on
OPENCV_LIB_TYPE:=SHARED
include ${OPENCVROOT}/sdk/native/jni/OpenCV.mk

LOCAL_SRC_FILES := com_fyp_major_fyp1_OpencvClass.cpp

LOCAL_LDLIBS += -llog
LOCAL_MODULE := MyLibs

include $(BUILD_SHARED_LIBRARY)

APPLICATION.mk

APP_STL := gnustl_static
APP_CPPFLAGS := -frtti -fexceptions
APP_ABI := armeabi-v7a
APP_PLATFORM := android-16

使用 ndk 18.1 时出现输出错误

使用 ndk 14.1 时出现输出错误

这些错误的任何解决方案?

【问题讨论】:

  • 可能是时候从自定义“ndkBuild”任务切换到externalNativeBuild 方法了。您可以保留您的 Android.mk 并享受完整的 IDE 集成。

标签: android opencv android-ndk


【解决方案1】:

NDK r18 已删除 gnustl,因此您必须rebuild OpenCV for libc++

至于 NDK r14.1,解释失败的信息太少。请注意,屏幕截图提到在那里运行的是 ndk-stack.cmd 而不是 ndk-build.cmd。当您切换到旧版 NDK 时,会不会是拼写错误?

【讨论】:

  • NDK r14.1 中,退出值 -1 是因为我运行的是 ndk-stack.cmd 而不是 ndk-build.cmd(如上所述)。现在我的代码运行没有任何错误。 @AlexThankyou ......但是如果我使用 NDK 18.1,我仍然有问题。请检查这些图像 (imgur.com/a/sW6K1pJ) 安装后我不会为 Cmake 做任何其他设置。只需在终端上运行代码。现在如何创建 Cmakelists.text?
  • 我不建议重建 OpenCV,在官方支持 r18 之前使用 NDK r14 会更安全。
猜你喜欢
  • 1970-01-01
  • 2018-11-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-11-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多