Android通过NDK使用jni库,报错cannot locate symbol "__aarch64_ldadd4_relax",如何解决?(语言-c语言|操作系统-android)

问题遇到的现象和发生背景

Android版本:R
abi:arm64-v8a
芯片:高通8155
报错库:自己在ubuntu中交叉编译zeromq得到的Android库
android交叉编译工具链:android-ndk-r24
问题描述:在APK中java侧通过System.loadLibrary加载so,但是在运行时报了错误,
java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "__aarch64_ldadd4_relax" referenced by "/data/app/~~7M30PxbA5TZn2HmzOnoe1w==/com.test.example-x0DRbnJHKw-KSA9-1Mk9rg==/base.apk!/lib/arm64-v8a/libzmq.so"...

问题相关代码

交叉编译指令:
export ANDROID_NDK_ROOT=~/toolchain/android-ndk-r24
export MIN_SDK_VERSION=28
./build.sh arm64

dev05@hello-PowerEdge-R740:~//libzmq$ find ./ -name *.so | xargs nm -D | grep ldadd
U __aarch64_ldadd4_acq
U __aarch64_ldadd4_acq_rel
U __aarch64_ldadd4_rel
U __aarch64_ldadd4_relax
U __aarch64_ldadd8_acq_rel
U __aarch64_ldadd8_relax
U __aarch64_ldadd4_acq
U __aarch64_ldadd4_acq_rel
U __aarch64_ldadd4_rel
U __aarch64_ldadd4_relax
U __aarch64_ldadd8_acq_rel
U __aarch64_ldadd8_relax

运行结果及报错内容

java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "__aarch64_ldadd4_relax" referenced by "/data/app/~~7M30PxbA5TZn2HmzOnoe1w==/com.test.example-x0DRbnJHKw-KSA9-1Mk9rg==/base.apk!/lib/arm64-v8a/libzmq.so"...
编译没有问题,apk在运行时,dlopen ndk的so,报错找不到__aarch64_ldadd4_relax

我的解答思路和尝试过的方法

之前在网上查找说,默认开启了-moutline-atomics,但是我使用的交叉编译命令是zeromq自带的,没有去修改CMakeLists.txt。。

另外网上说__aarch64_ldadd4_acq_rel在libgcc.a中,我将libgcc.a依赖进入到jni lib中,运行仍然报上面的错误。

我想要达到的结果

1、上述问题产生的原因
2、能够在Android中运行zeromq。

上层调用动态库,一般要加jni接口,然后用System.loadLibrary("库")的方式来调用
你说的 在APK中通过dlopen访问NDK侧的libzmq库 我不太明白

1.原因是:NDK工具版本不一致
2.解决:export ANDROID_NDK_ROOT=~/toolchain/android-ndk-r24 使用版本一致的NDK编译

话说该机安装的CPU支持相应指令吗?

dev05@hello-PowerEdge-R740:~//libzmq$ find ./ -name *.so | xargs nm -D | grep ldadd
你找了哪些so?

去404大站搜了下,找到了相关错误:

I searched the whole internet for a solution, but couldn't get a practical one. Actually, the root cause is simple: The Android NDK is too old.
The solution in my case is:

  • Upgrade CMake to the latest version.
  • Upgrade Android NDK to the latest version.

翻译过来大概意思就是NDK版本太旧导致的,推荐更新下CMake和NDK版本,然后重新编译。

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632