Android NDK React Native 混合使用32位和64位依赖项问题

本文分析了在VIVO手机上出现的Crash问题,详细解释了由于Android系统同时加载32位和64位so库导致的问题。并提供了解决方案,即通过在ndk配置中仅保留armeabi-v7a架构,避免32位和64位库混合加载引起的冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近遇到一个问题在VIVO的一些型号上发生Crash, log 信息如下:

java.lang.UnsatisfiedLinkError:
 couldn't find DSO to load: libreactnativejni.so 
 caused by: couldn't find DSO to load: libfb.so 
 caused by: couldn't find DSO to load: libgnustl_shared.so 
 caused by: dlopen failed: "/data/data/****/lib-main/libgnustl_shared.so" is 64-bit instead of 32-bit
原因分析

此问题引起Crash的主要原因
Android同时加载32位和64位so库出现问题,因为app在安装过程中,系统会对app进行解析根据so文件类型,如果有一个依赖库使用ARM64支持编译的扩展,而另外一些依赖库仅支持ARM32,就会出现问题。 系统将加载ARM64依赖,而拒绝加载仅ARM32的so库,就可能导致应用程序崩溃

问题解决

因为Android 32位和64位二进制混合加载容易出现问题,并且目前安卓设备绝大多数是 ARM 架构,armeabi-v7a支持大部分机型,因此对于大部分应用来说可以考虑去掉 x86 架构的支持(但是请注意模拟器大部分是 x86 架构,因此去掉 x86 架构后将无法在模拟器上运行)。

ndk {
    // 设置支持的SO库架构
    abiFilters 'armeabi-v7a'
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值