JNI排坑记录:java.lang.UnsatisfiedLinkError导致JVM崩溃

本次坑不大不小,在此记录一下,希望能够帮助遇到同样问题的朋友。

1.背景

最近在进行Seetaface6开源人脸识别库的Java封装工作。封装工作初步完成后,Java端进行封装测试,调用库dll文件都成功了,但调用本地Native方法(dll中的方法)时,报错:java.lang.UnsatisfiedLinkError,然后就没有其他任何提示信息了!跟其他人遇到的都不一样。

2.排坑

经过排查,实际错误发生的原因很简单,但是因为没有任何有价值的错误信息提示,导致坑了一定时间。

JNI开发时,根据Java中Native方法所在的类,比如名叫:com.aaa.bbb.MyClass,会对应生成一个名为“com_aaa_bbb_MyClass.h”的头文件,然后再引入到C/C++工程中,进行dll库的开发。

然后在Java端加载dll库,并调用MyClass中的Native方法就可以了。但我犯了一个致命错误,我把MyClass的包,最终改为了比如:com.xxx.yyy.MyClass,导致调用Native方法时报出“java.lang.UnsatisfiedLinkError”的错误(问题是还没有其他多余信息提示),从而引起JVM崩溃整个程序退出。

3.结论

最终结论:关键点就在于:“Java端Native方法所在类名称和包名必须与C端一致”!意思就是com.aaa.bbb.MyClass这个从包名到类名一个字都不能改!!!

我把com.xxx.yyy.MyClass改回com.aaa.bbb.MyClass再调用Native方法就正常了。

这个坑是我大意了,也希望其他朋友要小心这一点。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
loadlibrary msc error: java.lang.unsatisfiedlinkerror是指在尝试加载msc库时发生了链接错误,而无法成功加载该库。这个错误一般会在使用Java Native Interface(JNI)调用本地C或C++库时出现。 这个错误通常有以下几个可能的原因: 1. 缺少msc库文件:在加载msc库之前,首先要确保在系统中存在该库文件,且文件路径正确。如果库文件缺失或路径不正确,就会导致加载错误。解决方法是确认msc库文件是否存在,并将其放置在正确的路径中。 2. 库文件版本不匹配:msc库文件可能是针对特定版本的操作系统或其他依赖库进行编译的。如果所使用的库文件版本与当前系统环境不匹配,就会导致加载错误。解决方法是确认所使用的msc库文件版本与当前系统环境的兼容性,并相应地进行更新或更换。 3. 环境配置错误:在调用JNI时,有时需要手动设置一些环境变量或添加一些系统属性。如果这些配置错误或缺失,就可能导致msc库加载错误。解决方法是检查环境配置是否正确,并进行必要的更改或补充。 4. 其他问题:除上述可能的原因外,还有可能是其他系统配置或运行时问题导致的加载错误。这种情况下,可以尝试重新安装msc库,检查相关日志或错误信息,以便更加准确地定位问题所在,并采取相应的解决措施。 总之,loadlibrary msc error: java.lang.unsatisfiedlinkerror是在尝试加载msc库时发生的链接错误,可能的原因包括缺少库文件、库文件版本不匹配、环境配置错误等。根据具体情况,可以采取适当的解决方法来解决该错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值