【精神哥讲Crash】第一期:UnsatisfiedLinkError

本文由腾讯Bugly的资深研究员精神哥分享,深入剖析Android中的UnsatisfiedLinkError错误,包括其基本介绍和常见错误场景,如缺少SO文件、设备架构不匹配等。通过实例解析了导致“dlopen failed: ... has unexpected e_machine: 3”的问题,为开发者提供了解决这类Crash的思路。

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

大家好,我是腾讯Bugly的精神哥(英文名:spirit),是Bugly资深码奴的同时,又是Bugly神秘的Crash实验室研究员哦!我的主要任务就是泡在实验室里,嗑着瓜子嚼着鸡爪,研究移动App中各种Crash(专挑疑难、坑爹、时髦、有趣的Crash),并通过“精神哥讲Crash”系列定期分享给大家!

今天精神哥给大家分享的第一个Crash是“UnsatisfiedLinkError” 。


一、UnsatisfiedLinkError基本介绍

全名

java.lang.UnsatisfiedLinkError

官方解释

Throw if the java Virtural Machine cannot find an appropriate native-language definition of method declared native

意思就是JVM找不到native method的native实现!

影响力排名

出错量排名第16位

精神哥点评

抛出这异常,肯定是你加载SO的姿势不对!


现在App很多功能都是通过集成第三方工具实现的,第三方工具很有可能在SO动态库里实现核心功能(Bugly提供的libBugly.so,能捕获这类C/C++异常!),所以就算你不用NDK开发也一定会跟SO打交道,你确定你加载SO的姿势都对了吗?

 

二、错误场景分析

1、低级错误——根本木有SO,你加载个球啊!

code

System.loadLibrary(Bugly);

libs

运行设备

Android ARM设备

运行结果

Crash!

java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.tencent.bugly.demo-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /systemb]]] couldn't find "libBugly.so"

原因分析

apk安装时,系统会把apk中libs目录下armeabi的SO拷贝到应用的私有目录下。

所以libs里没有放入SO,运行时肯定找不到SO。

修复方式

添加SO:libs\armeabi\libBugly.so

加载代码注释掉://System.loadLibrary(Bugly) ;

2、进阶错误——根本木有X86的SO,在X86的设备上你加载个球啊! 

code

System.loadLibrary(Bugly);

libs

libs\armeabi\libBugly.so

运行设备

Android X86设备

运行结果

Crash!

java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.tencent.bugly.demo-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /systemb]]] couldn't find "libBugly.so"

原因分析

apk安装时,x86设备上系统会把apk中libs目录下x86的SO,拷贝到应用的私有目录下。

虽然libs下有armeabi的SO,但没有放入x86的SO,运行时还是找不到libbugly.so。

修复方式

添加SO:libs\x86\libBugly.so

加载代码注释掉://System.loadLibrary(Bugly) ;


3、大坑——尼玛,好难发现! 

code

if(getArch().contain(“arm”)){

//只在arm下加载

System.loadLibrary(Bugly) ;

System.loadLibrary(Bugly2);

}

libs

libs\armeabi\libBugly.so

libs\armeabi\libBugly2.so

libs\armeabi-v7a\libBugly.so

运行设备

Android ARMv7设备

运行结果

Crash!

java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.tencent.bugly.demo-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /systemb]]] couldn't find "libBugly2.so"

原因分析

apk安装时,系统会把apk中libs目录下armeabi-v7a整个目录下的SO拷贝到应用的私有目录下。

因为armeabi-v7a下没有放入libBugly2.so,运行时找不到libBugly2.so。

不同的工具兼容的CPU架构不一致,就容易出这个错误了!

例如:

libBugly.so提供armeabi、armeabi-v7a、x86三种。

但其它产品可能只提供了armeabi。

如果把这些so都直接拷贝进apk,就会因为上述的原因直接crash,会误以为该Crash是因为不同产品的so不能兼容导致的!

修复方式

添加SO:libs\armeabi-v7a\libBugly2.so

直接删除armeabi-v7a目录,arm设备上系统会自动选择armeabi


4、天坑——尼玛,巨难发现! 

虽然出错原因很简单,但犯错的人很确实多,这货都挤到Bugly Crash影响力第16位了!

精神哥发现java.lang.UnsatisfiedLinkErrorcouldn't find “XX.so”的占比非常高,上面提的三个场景都是这种错误!

但你见过下面这种错误吗?

java.lang.UnsatisfiedLinkError:dlopenfailed: “**/*/arm/*.so" has unexpected e_machine: 3

如何出现的呢?

code

if(getArch().contain(“arm”)){

//只在arm下加载

System.loadLibrary(Bugly) ;

}

libs

libs\armeabi\libBugly.so坑爹实习生放入了x86编译的libBugly.so(同名很容易出错)

运行设备

Android ARM设备

运行结果

Crash!

java.lang.UnsatisfiedLinkError: dlopen failed: "/data/app/com.tencent.bugly.crashreport.demo-2/lib/arm/libBugly.so" has unexpected e_machine: 3

原因分析

apk安装时,系统把armeabi下的libBugly.so放入应用的私有目录中了!

但这个libBugly.so不是arm的,而是x86编译的libBugly.so

运行时,系统检察ELF文件中的e_machine字段的值,跟arm的不匹配,就会抛出这个异常了!

 “精神哥讲Crash”第一期圆满结束,感谢大家支持,也敬请期待下次分享!


本文系腾讯Bugly特邀文章,转载请注明作者和出处“腾讯Bugly(http://bugly.qq.com)”

 


07-22 18:02:18.502 11831 11831 I Typeface: Preloading /system/fonts/Roboto-Regular.ttf 07-22 18:02:18.542 11831 11831 V GraphicsEnvironment: ANGLE Developer option for 'com.taixin.txallremote' set to: 'default' 07-22 18:02:18.542 11831 11831 V GraphicsEnvironment: ANGLE GameManagerService for com.taixin.txallremote: false 07-22 18:02:18.543 11831 11831 V GraphicsEnvironment: Neither updatable production driver nor prerelease driver is supported. 07-22 18:02:18.544 11831 11831 D NetworkSecurityConfig: No Network Security Config specified, using platform default 07-22 18:02:18.545 11831 11831 D NetworkSecurityConfig: No Network Security Config specified, using platform default 07-22 18:02:18.545 11831 11831 I : application init 07-22 18:02:18.552 11831 11853 D libEGL : loaded /system/lib/egl/libEGL_emulation.so 07-22 18:02:18.553 11831 11853 I nemucooker: cook file1: /etc/mumu-configs/renderer.config, last modify time: Thu Aug 29 11:22:45 2024 07-22 18:02:18.553 11831 11853 I nemucooker: cook file2: /data/system/etc/mumu-configs/renderer.config, last modify time: Thu Jul 17 21:45:34 2025 07-22 18:02:18.553 11831 11853 I nemucooker: cook select file: /data/system/etc/mumu-configs/renderer.config 07-22 18:02:18.566 11831 11853 D libEGL : loaded /system/lib/egl/libGLESv1_CM_emulation.so 07-22 18:02:18.568 11831 11853 D libEGL : loaded /system/lib/egl/libGLESv2_emulation.so 07-22 18:02:18.590 11831 11853 E GraphicsEnv: Failed to get gpu service 07-22 18:02:18.599 11831 11831 I txallremote-H6RemoteIO: load library: libtxporting-i2c.so 07-22 18:02:18.600 11831 11831 E ziparchive: Zip: lseek on fd -2 failed: Bad file descriptor 07-22 18:02:18.625 11831 11831 I txallremote-H6RemoteIO: txallremote init 07-22 18:02:18.626 11831 11831 E xin.txallremot: No implementation found for void com.taixin.txallremote.jni.H6RemoteIO.TxAllRemote_Init() (tried Java_com_taixin_txallremote_jni_H6RemoteIO_TxAllRemote_1Init and Java_com_taixin_txallremote_jni_H6RemoteIO_TxAllRemote_1Init__) 07-22 18:02:18.626 11831 11831 D AndroidRuntime: Shutting down VM 07-22 18:02:18.627 11831 11831 E AndroidRuntime: FATAL EXCEPTION: main 07-22 18:02:18.627 11831 11831 E AndroidRuntime: Process: com.taixin.txallremote, PID: 11831 07-22 18:02:18.627 11831 11831 E AndroidRuntime: java.lang.UnsatisfiedLinkError: No implementation found for void com.taixin.txallremote.jni.H6RemoteIO.TxAllRemote_Init() (tried Java_com_taixin_txallremote_jni_H6RemoteIO_TxAllRemote_1Init and Java_com_taixin_txallremote_jni_H6RemoteIO_TxAllRemote_1Init__) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at com.taixin.txallremote.jni.H6RemoteIO.TxAllRemote_Init(Native Method) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at com.taixin.txallremote.jni.H6RemoteIO.remoteOpen(H6RemoteIO.java:17) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at com.taixin.txallremote.dataway.RemoteDirectIo.getInstance(RemoteDirectIo.java:27) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at com.taixin.txallremote.activity.TempHumiControlManagerActivity.onCreate(TempHumiControlManagerActivity.java:81) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.Activity.performCreate(Activity.java:8054) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.Activity.performCreate(Activity.java:8034) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1347) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3736) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3931) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:103) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2294) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:106) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.os.Looper.loopOnce(Looper.java:201) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.os.Looper.loop(Looper.java:288) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:8060) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:571) 07-22 18:02:18.627 11831 11831 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1091) 07-22 18:02:18.651 11831 11831 I Process : Sending signal. PID: 11831 SIG: 9 07-22 18:02:18.673 1251 2855 I ActivityManager: Process com.taixin.txallremote (pid 11831) has died: fg TOP 07-22 18:02:18.673 1055 1055 I Zygote : Process 11831 exited due to signal 9 (Killed) 07-22 18:02:18.673 1251 1291 I libprocessgroup: Successfully killed process cgroup uid 10109 pid 11831 in 0ms 07-22 18:02:24.472 1091 1091 D opengl-gc: Check pid 11831: running 0
最新发布
07-23
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值