- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用 NDK 为 android 构建一个 C++ 可执行文件。可执行(./main)源文件 main.c 非常简单:
#include <stdio.h>
#include <stdlib.h>
int main()
{
printf("Hello World\n");
return 0;
}
我可以使用 cmake 和 android-cmake-toolchain 构建它。之后我把它放在 Android 设备上:
# this script is used to put binary to the device
import subprocess
output_executable = 'libs/armeabi-v7a/main /data/local/tmp/main'
# step 1: push
push_cmd = 'adb push '+output_executable
subprocess.check_call(push_cmd,stderr=subprocess.STDOUT, shell=True)
# step 2: change mode
mod_cmd = 'adb shell chmod 777 '+output_executable
subprocess.check_call(mod_cmd,stderr=subprocess.STDOUT, shell=True)
# step 3: run the program
run_cmd = 'adb shell '+output_executable
subprocess.check_call(run_cmd,stderr=subprocess.STDOUT, shell=True)
一切正常。但是,如果我只是把main.c改成main.cpp,然后照着做,编译就没问题了。但是当它放在 Android 设备上时,我收到以下错误消息:
soinfo_link_image(linker.cpp:1635): could not load library "libgnustl_shared.so" needed by "/data/local/tmp/main"; ....
我觉得应该根据报错提示指出STL库在Android平台的位置。任何想法将不胜感激。
最佳答案
.cpp
扩展使 NDK build
使用 c++ 编译器并与一些 c++ 库链接。您应该使用 -nodefaultlibs
选项并明确定义要链接的库。
另外,看看 SO: g++, static initialization and -nostdlib .
更新。
添加了日志(针对非信徒)。
当文件有 .c
扩展名时:
C:\Dev\Projects\NdkTest\jni>ndk-build -B V=1
[armeabi] Compile thumb : hello-jni <= main.c
C:/Dev/Tools/Android/ndk-r10d/toolchains/arm-linux-androideabi-4.8/pre
built/windows-x86_64/bin/arm-linux-androideabi-gcc -MMD -MP -MF
C:\Dev\Projects\NdkTest/ob j/local/armeabi/objs/hello-jni/main.o.d
-fpic -ffunction-sections -funwind-tables -fstack-protector
-no-canonical-prefixes -march=armv5te -mtune=xscale -msoft-f loat
-mthumb -Os -g -DNDEBUG -fomit-frame-pointer -fno-strict-aliasing
-finline-limit=64 -IC:\Dev\Projects\NdkTest/jni -DANDROID
-Wa,--noexecstack -Wformat -We rror=format-security
-IC:/Dev/Tools/Android/ndk-r10d/platforms/android-3/arch-arm/usr/inclu
de -c C:\Dev\Projects\NdkTest/jni/main.c -o C:\Dev\Projects\NdkTe
st/obj/local/armeabi/objs/hello-jni/main.o
[armeabi] Executable : hello-jni
C:/Dev/Tools/Android/ndk-r10d/toolchains/arm-linux-androideabi-4.8/pre
built/windows-x86_64/bin/arm-linux-androideabi-g++ -Wl,--gc-sections
-Wl,-z,nocopyreloc --
sysroot=C:/Dev/Tools/Android/ndk-r10d/platforms/android-3/arch-arm
-Wl,-rpath-link=C:/Dev/Tools/Android/ndk-r10d/platforms/android-3/arch
-arm/usr/lib -Wl,-rpath
-link=C:\Dev\Projects\NdkTest/obj/local/armeabi
C:\Dev\Projects\NdkTest/obj/local/armeabi/objs/hello-jni/main.o -lgcc
-no-canonical-prefixes -Wl,--no-undefined -Wl,-z,noexecstack
-Wl,-z,relro -Wl,-z,now -mthumb -lc -lm -o
C:\Dev\Projects\NdkTest/obj/local/armeabi/hello-jni
[armeabi] Install : hello-jni => libs/armeabi/hello-jni
copy /b/y "C:\Dev\Projects\NdkTest\obj\local\armeabi\hello-jni"
"C:\Dev\Projects\NdkTest\libs\armeabi\hello-jni" > NUL
C:/Dev/Tools/Android/ndk-r10d/toolchains/arm-linux-androideabi-4.8/pre
built/windows-x86_64/bin/arm-linux-androideabi-strip --strip-unneeded
C:\Dev\Projects\Ndk Test/libs/armeabi/hello-jni
当文件有 .cpp
扩展名时:
C:\Dev\Projects\NdkTest\jni>ndk-build -B V=1
[armeabi] Compile++ thumb: hello-jni <= main.cpp
C:/Dev/Tools/Android/ndk-r10d/toolchains/arm-linux-androideabi-4.8/pre
built/windows-x86_64/bin/arm-linux-androideabi-g++ -MMD -MP -MF
C:\Dev\Projects\NdkTest/ob j/local/armeabi/objs/hello-jni/main.o.d
-fpic -ffunction-sections -funwind-tables -fstack-protector
-no-canonical-prefixes -march=armv5te -mtune=xscale -msoft-f loat
-fno-exceptions -fno-rtti -mthumb -Os -g -DNDEBUG -fomit-frame-pointer
-fno-strict-aliasing -finline-limit=64
-IC:/Dev/Tools/Android/ndk-r10d/sources/cxx-s tl/system/include
-IC:\Dev\Projects\NdkTest/jni -DANDROID -Wa,--noexecstack -Wformat
-Werror=format-security -IC:/Dev/Tools/Android/ndk-r10d/platforms/and
roid-3/arch-arm/usr/include -c C:\Dev\Projects\NdkTest/jni/main.cpp -o
C:\Dev\Projects\NdkTest/obj/local/armeabi/objs/hello-jni/main.o
[armeabi] StaticLibrary : libstdc++.a
C:/Dev/Tools/Android/ndk-r10d/toolchains/arm-linux-androideabi-4.8/pre
built/windows-x86_64/bin/arm-linux-androideabi-gcc-ar crsD
C:\Dev\Projects\NdkTest/obj/loc al/armeabi/libstdc++.a
[armeabi] Executable : hello-jni
C:/Dev/Tools/Android/ndk-r10d/toolchains/arm-linux-androideabi-4.8/pre
built/windows-x86_64/bin/arm-linux-androideabi-g++ -Wl,--gc-sections
-Wl,-z,nocopyreloc --
sysroot=C:/Dev/Tools/Android/ndk-r10d/platforms/android-3/arch-arm
-Wl,-rpath-link=C:/Dev/Tools/Android/ndk-r10d/platforms/android-3/arch
-arm/usr/lib -Wl,-rpath
-link=C:\Dev\Projects\NdkTest/obj/local/armeabi
C:\Dev\Projects\NdkTest/obj/local/armeabi/objs/hello-jni/main.o
C:\Dev\Projects\NdkTest/obj/local/armeabi/libstd c++.a -lgcc
-no-canonical-prefixes -Wl,--no-undefined -Wl,-z,noexecstack
-Wl,-z,relro -Wl,-z,now -mthumb
-LC:/Dev/Tools/Android/ndk-r10d/platforms/android-3/a rch-arm/usr/lib
-lstdc++ -lc -lm -o
C:\Dev\Projects\NdkTest/obj/local/armeabi/hello-jni
[armeabi] Install : hello-jni => libs/armeabi/hello-jni
copy /b/y "C:\Dev\Projects\NdkTest\obj\local\armeabi\hello-jni"
"C:\Dev\Projects\NdkTest\libs\armeabi\hello-jni" > NUL
C:/Dev/Tools/Android/ndk-r10d/toolchains/arm-linux-androideabi-4.8/pre
built/windows-x86_64/bin/arm-linux-androideabi-strip --strip-unneeded
C:\Dev\Projects\Ndk Test/libs/armeabi/hello-jni
如您所见,将文件扩展名重命名为 .cpp
使 ndk-build
使用不同的编译器并链接到其他库。
更新 2.
1) 如果您不需要gnuSTL_shared
,请更新您的Android.mk
LOCAL_CXXFLAGS += -nostdinc++ -I...
LOCAL_LDFLAGS += -nodefaultlibs -L...
LOCAL_LDLIBS += lc -lm -ldl -l...
2) 如果您确实需要 gnuSTL_shared
,请更新您的部署脚本
import subprocess
output_dir = 'libs/armeabi-v7a/'
output_files = ['main', 'libgnustl_shared.so']
target_dir = '/data/local/tmp/'
target_executable = target_dir+'main'
# step 1: push
for f in output_files:
push_cmd = 'adb push '+output_dir+f+' '+target_dir+f
subprocess.check_call(push_cmd,stderr=subprocess.STDOUT, shell=True)
# step 2: change mode
mod_cmd = 'adb shell chmod 777 '+target_executable
subprocess.check_call(mod_cmd,stderr=subprocess.STDOUT, shell=True)
# step 3: run the program
run_cmd = 'adb shell LD_LIBRARY_PATH='+target_dir.rstrip('/')+':$LD_LIBRARY_PATH '+target_executable
subprocess.check_call(run_cmd,stderr=subprocess.STDOUT, shell=True)
为什么要更新 LD_LIBRARY_PATH
请参阅 SO: Android – how to load shared library?
关于android - 为什么C++可执行文件在Android设备上找不到动态库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28567381/
http://www.vex.net/~trebla/haskell/so.xhtml描述如何编译共享库。 关于编译命令: ghc -O2 -dynamic -shared -fPIC -o libE
我想从Rust调用一个C++动态库(* .so),但是我不想从Rust构建它。像这样, cc::Build::new() .file("src/foo.cc") .shared_fla
我想问一下,打包在ear中的war是否可以使用war文件中没有打包的库。我想在文件系统上拥有包含库的目录,部署的 war 文件将从该目录加载库。我还没有找到如何执行此操作的示例。所以我想问一下部署的w
我正在制作一个 C++ 库。在库中,我正在使用另一个静态库中的一些函数(例如 ref.a)。 我想生成一个库文件,mylib.a 或 mylib.so,这样使用我的库的任何程序都不需要链接到静态库 (
我正在尝试在 linux 中为一个使用 opencv 和 tesseract 以及动态链接的程序创建一个共享库 我关注了link我的代码如下 g++ -c Serial_Key.cpp -fPIC -
[编辑:简而言之,问题是:当我链接到一个链接到另一个动态库的动态库时,我是否也必须显式链接到那个?] 我在一个软件中看到了类似的东西。它不起作用,现在我想知道它是否应该起作用。我可以将库“bar”动态
我的项目中有一堆 Dll,使用 VStudio 9.0 编译器,预编译头文件用于我所有的 Dll。 dll 的加载过程由隐式调用程序完成(必须提供.dll、.lib 和 header )。 我通常为每
在我开始开发更多的 c++ 项目之前,我想建立一个良好的多平台环境并使用一些基本形式的修订 (rsync)。为此,我学习了如何构建 makefile(使用 uname 变量)并且还开始在 Window
我测试试,导出dll成功了,但是调用exe编译失败。 后来把声明代码改为了dllexport,调用exe编译成功了,调用也成功。 #pragma once #ifdef YOLOFACE_DLL_AP
我的问题很简单。有什么方法可以反编译、逆向工程 DYLIB 文件(MAC 的动态库,如 Windows DLL)。? 推荐什么程序这样做? 我正在寻找类似 Olly 或 IDA 之类的程序,但适用于
我已将我的应用提交到App Store,但遭到拒绝。我收到一封电子邮件,说: 无效的捆绑包-dylib搜索路径中不存在您的应用程序引用的一个或多个动态库。 我没有使用CocoaPods,所以所有外部框
我在 CPython 中使用 pythonnet,并且我成功安装了它 import clr clr.AddReference('Assembly') 确实有效。 在我的 C# 代码中,如果是成员 pu
GCC 简介有一个例子: $ gcc -Wall -L. main.c -lhello -o hello The option ‘-L.’ is needed to add the current d
我知道当您使用 dlopen() 加载动态 C++ 库时,您可以获得指向该库内函数的指针,但是有没有一种方法可以有效地(性能很重要)另一个怎么办? 我知道我可以在库中调用一个函数(在初始化库时),将一
给程序和库添加版本号和库,有利于维护和升级。 当然你可以在文件名上体现,比如有个程序叫 yun,文件名写为 yun_1.0.2,但这个需要每次手动维护,而且不能100%确保当前程序就是那个版本。所
我正在尝试将我的 C 程序链接到静态库和动态库以查看差异。我怎么做?我制作了自己的 Makefile: # ------ executable rule ----------- app : app.
假设我想创建一个动态库 dynamic.so,但我的代码引用了某个其他静态库 static.a 中存在的函数。自然地,如果我使用 g++ 和 -shared 选项进行编译和链接,dynamic.so
我想使用 alarm函数有一个中断来安排对 fcntl + F_SETLKW 的阻塞调用超时(用于锁定文件获取)。但是,我的代码位于共享库/dylib(主机应用程序的插件)中,alarm 的文档指出这
【目录】 第一个动态库文件 应用程序 第二个动态库文件 错误做法:直接给它改名 正解:patchelf 工具 One More Thing
什么是模块化编程 模块化编程就是我们一个复杂的项目分成很多模块,比如一个单片机项目,就可能分为:主函数模块,液晶显示和数码管显示模块,时间延时模块,温度传感器模块等。而一个程序工程包含多个源文件(.c
我是一名优秀的程序员,十分优秀!