xamarin.android引用so文件时,遇到的错误

冯胤
2023-12-01

Java.Lang.UnsatisfiedLinkError: Couldn't load smartshelljni from loader dalvik.system.PathClassLoader[dexPath=/data/app/XXXNfc.XXXNfc-8.apk,libraryPath=/data/app-lib/XXXNfc.XXXNfc-8]: findLibrary returned null


在lib 发现明明有smartshelljni.so这个文件,但是为何还是报错呢....写了一个Demo 发现,没有报错,最后一个一个推测,发现

区别在于 armeabi和armeabi-v7a

如果armeabi文件夹下还有其他的 .so文件,也需要一并copy至armeabi-v7a


而这个armeabi和armeabi-v7a究竟是什么意思?


有什么深意么?


为什么调试模式和发行模式adobe会选择不同的文件夹?

查了以下

armeabi与armeabi-v7a表示支持不同的CPU类型
armeabi是指的该so库用于ARM的通用CPU,而v7a的CPU支持硬件浮点运算。因此armeabi通用性强,但速度慢,而v7a能充分发挥v7a CPU的能力,在AIR打包APK调试模式adobe选择的是通用性强的armeabi模式。


Android支持不同CPU的深层含义
首先从硬件支持方便来看,我们的adnroid设备目前为止大部分都是支持ARM芯片,(当然市面上此刻最新的android机器还支持intel等另外的几个芯片,例如intel最新的凌动项目芯片,就获得了android4.1的青睐)。从android版本与支持ARM硬件编码的程度来看:


起初android1.6:只支持armv4与armv5te指令集。


到了android2.0:增加了支持arm-vfp,armv6,armv6t2指令集。


到了android2.2:增加支持armv7-a指令集。


所以armeabi-v7a 应该是与AIR限定支持android2.2以上的条件有关。android2.2以上能让硬件发挥更大的作用。


我项目中使用armeabi还是armeabi-v7a
对于AIR项目来说性能问题是最大的瓶颈,能优化一点就一点,所以如果接平台方SDK或者写ANE的时候使用到SO库,个人推荐全部放到armeabi-v7a下,而不要为了兼容放到armeabi。


 类似资料: