clang++.exe: error: linker command failed with exit code 1 (use -v to see invocation)

Build command failed.
Error while executing process D:\AndroidStudio\Android\Sdk\cmake\3.6.4111459\bin\cmake.exe with arguments {--build F:\ccc\app\.externalNativeBuild\cmake\debug\armeabi-v7a --target native-lib}
[1/7] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/arcterncomm.pb.cc.o
[2/7] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/arcternWrap/ArcternAlgorithm.cpp.o
[3/7] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/Main.cpp.o
[4/7] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/DataSocket.cpp.o
[5/7] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o
[6/7] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/FixFrameSizeBufferQueue.cpp.o
[7/7] Linking CXX shared library F:\ccc\jniLibs\armeabi-v7a\libnative-lib.so
FAILED: cmd.exe /C "cd . && D:\AndroidStudio\Android\Sdk\ndk-bundle\toolchains\llvm\prebuilt\windows-x86_64\bin\clang++.exe  --target=armv7-none-linux-androideabi --gcc-toolchain=D:/AndroidStudio/Android/Sdk/ndk-bundle/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64 --sysroot=D:/AndroidStudio/Android/Sdk/ndk-bundle/platforms/android-23/arch-arm -fPIC -g -DANDROID -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -fno-integrated-as -mthumb -Wa,--noexecstack -Wformat -Werror=format-security  -g -DANDROID -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -fno-integrated-as -mthumb -Wa,--noexecstack -Wformat -Werror=format-security  -std=c++11 -mfpu=neon -O0 -fno-limit-debug-info -O0 -fno-limit-debug-info  -Wl,--build-id -Wl,--warn-shared-textrel -Wl,--fatal-warnings -Wl,--fix-cortex-a8 -Wl,--no-undefined -Wl,-z,noexecstack -Qunused-arguments -Wl,-z,relro -Wl,-z,now -Wl,--build-id -Wl,--warn-shared-textrel -Wl,--fatal-warnings -Wl,--fix-cortex-a8 -Wl,--no-undefined -Wl,-z,noexecstack -Qunused-arguments -Wl,-z,relro -Wl,-z,now -shared -Wl,-soname,libnative-lib.so -o F:\ccc\jniLibs\armeabi-v7a\libnative-lib.so CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o CMakeFiles/native-lib.dir/src/main/cpp/arcternWrap/ArcternAlgorithm.cpp.o CMakeFiles/native-lib.dir/src/main/cpp/DataSocket.cpp.o CMakeFiles/native-lib.dir/src/main/cpp/FixFrameSizeBufferQueue.cpp.o CMakeFiles/native-lib.dir/src/main/cpp/Main.cpp.o CMakeFiles/native-lib.dir/src/main/cpp/arcterncomm.pb.cc.o  ../../../../src/main/jniLibs/armeabi-v7a/libarctern.a ../../../../src/main/jniLibs/armeabi-v7a/libcryptopp.a ../../../../src/main/jniLibs/armeabi-v7a/libflatbuffers.a ../../../../src/main/jniLibs/armeabi-v7a/libopencv_java3.so ../../../../src/main/jniLibs/armeabi-v7a/libdmlc.a ../../../../src/main/jniLibs/armeabi-v7a/libmxnet.so -lgomp ../../../../../protobuf_for_android/src/main/protobuf/jniLibs/armeabi-v7a/libprotobuf.so -llog -landroid -lm "D:/AndroidStudio/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/libs/armeabi-v7a/libsupc++.a" "D:/AndroidStudio/Android/Sdk/ndk-bundle/sources/cxx-stl/gnu-libstdc++/4.9/libs/armeabi-v7a/libgnustl_shared.so" && cd ."
D:/AndroidStudio/Android/Sdk/ndk-bundle/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/lib/gcc/arm-linux-androideabi/4.9.x/../../../../arm-linux-androideabi/bin\ld: error: ../../../../src/main/jniLibs/armeabi-v7a/libflatbuffers.a:1:1: syntax error, unexpected '!', expecting $end

D:/AndroidStudio/Android/Sdk/ndk-bundle/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/lib/gcc/arm-linux-androideabi/4.9.x/../../../../arm-linux-androideabi/bin\ld: error: ../../../../src/main/jniLibs/armeabi-v7a/libflatbuffers.a: not an object or archive

clang++.exe: error: linker command failed with exit code 1 (use -v to see invocation)

ninja: build stopped: subcommand failed.

报了如上的错误,libnative-lib.so链接时候出错,应该是没有生成这个so库文件。发现其实是一个依赖文件,用compare对比工具发现本来是unix编码,上传到git并拉下来后变成了pc编码,其实vi打开后set ff发现是dos。

关于"git submodule",首先关键字"sourcetree submodule"搜到文章<在SourceTree中使用Git submodule>,注意在add子模块的时候,如果依赖的是子模块的某个分支,则需要在add后面加上-b 分支名("git branch -a"命令后的某个远程分支,即"remotes/origin/"后面的某个远程分支名),如"git submodule add -b libs-gnustl git@xxx.git protobuf_for_android/src/main/protobuf ";关于从git上拉取后子模块代码的拉取参考文章<git中submodule子模块的添加、使用和删除>的"子模块的使用",即执行init和update。奇怪后面当其他同事更新了子模块后,在之前下载的工程代码中重复执行"git submodule init"、"git submodule update"并没有把最新的子模块代码拉下来,就算把之前的子模块目录重命名重新执行init和update也没有成功拉下来,后来就参考了文章<Git Submodule管理项目子模块>,在"更新子模块"标签下执行"方法二,先进入子模块,然后切换到需要的分支"就可以了,如果不行那就再执行"git submodule update"或者"git pull"就可以了。后来在做submodule依赖基础库的时候,也参考了<Android组件化项目如何利用Git的Submodule>、<GIT SUBMODULE在Android中的使用>、<Android 主工程submodule(.gitmodules)的添加、删除与更新>、<submodule集成第三方库>、<git submodule的使用,主项目和公共库关联起来>,这些文章内容都大同小异。

关于git的core.autocrlf,unix编码的文件上传到git的代码再拉下来后会变成dos格式(vi后:set ff查看),这个.a文件会导致链接不成功,后来参考了下文章<git 换行符LF与CRLF转换问题>,把默认的core.autocrlf从true修改为false后然后再拉取代码下来发现这个问题就没有了,而且直接网页下载出问题的文件,用vi打开后set fileformat查看也是unix格式的,看来完全都是git的core.autocrlf的原因,虽然set ff会不一样,但是用set fileencoding发现都是utf-8编码格式。其实文章<git 自动转换行符的坑爹案例>也给出了相同的解决方案。在一开始碰到这个问题的时候看了文章<Git LF和CRLF问题解决记录>,由于原文作者一通修改后,"前面一顿命令敲下去把自己git的配置文件全部给整乱了!",他最后为了清理删除了.gitconfig中的autocrlf,其实就是前面两篇解决方案中加到.gitconfig文件中配置,而且该文章第一句加的配置并不完整,另外两篇中指出还需要设置core.safecrlf为true,不过该文章指出"git config --list"可以列出配置项,还是挺好的。

       关于c++调用java方法,c++中传递std::string类型参数,java中是String类型参数,调用的时候需要通过env->NewStringUTF做一次转换。而且在GetMethodID获取java函数签名时用"Ljava/lang/String;"代表String类型,而不是根据int的"I"想当然成"S"。而且关于跨线程的AttachCurrentThread和DetachCurrentThread可以参考文章<JNI层AttachCurrentThread与DetachCurrentThread>,跟人理解就是如果是多个线程要调用java的这个回调,就需要调用AttachCurrentThread。一开始想当然的加上DetachCurrentThread,结果报错"attempting to detach while still running code",后来去掉后就能正常运行。

       关于andorid中一个应用如何导入基础库,参考了文章<导入一个AndroidStudio工程作为一个Library Module>、<android studio将一个项目作为module(library)导入到另一个项目>和<Android studio 一个项目引入另一个项目作为Libary>,实现应用工程导入一个库工程。

发布了16 篇原创文章 · 获赞 2 · 访问量 1万+
展开阅读全文

android studio NDK cmake创建的demo例子无法正常运行错误如下,如何解决该问题 求助求助

11-10

Caused by: org.gradle.internal.UncheckedException: Build command failed. Error while executing process E:\androidAdt\sdk\cmake\3.6.4111459\bin\cmake.exe with arguments {--build F:\workspace\AutoPayStation\app\.externalNativeBuild\cmake\debug\armeabi-v7a --target native-lib} [1/2] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o FAILED: E:\androidAdt\android-ndk-r16b\toolchains\llvm\prebuilt\windows-x86_64\bin\clang++.exe --target=armv7-none-linux-androideabi --gcc-toolchain=E:/androidAdt/android-ndk-r16b/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64 --sysroot=E:/androidAdt/android-ndk-r16b/sysroot -Dnative_lib_EXPORTS -isystem E:/androidAdt/android-ndk-r16b/sources/cxx-stl/gnu-libstdc++/4.9/include -isystem E:/androidAdt/android-ndk-r16b/sources/cxx-stl/gnu-libstdc++/4.9/libs/armeabi-v7a/include -isystem E:/androidAdt/android-ndk-r16b/sources/cxx-stl/gnu-libstdc++/4.9/include/backward -isystem E:/androidAdt/android-ndk-r16b/sysroot/usr/include/arm-linux-androideabi -D__ANDROID_API__=19 -g -DANDROID -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -fno-integrated-as -mthumb -Wa,--noexecstack -Wformat -Werror=format-security -frtti -fexceptions -std=c++11 -O0 -fno-limit-debug-info -fPIC -MD -MT CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o -MF CMakeFiles\native-lib.dir\src\main\cpp\native-lib.cpp.o.d -o CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o -c F:\workspace\AutoPayStation\app\src\main\cpp\native-lib.cpp,, 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览