java jna java.lang.UnsatisfiedLinkError: Unable to load library Native library (win32-x86-64/C:\User

背景

在新装的win系统下,java项目人脸识别项目要调用动态库,下面就说说问题

问题

Exception in thread “main” java.lang.UnsatisfiedLinkError: Unable to load library ‘C:\xxx\xxx\xxx\xxx.dll’: Native library (win32-x86-64/C:\xxx\xxx\xxx\xxx.dll) not found in resource path

我是拷贝git issues上的,因为当时我没记录这些错误。这错误大概就长这样,花费了我一天半时间。
在这个过程也了解了很多java jna的知识。

当时的分析

当时就觉得路径不对导致加载不到dll,所以通过jna.class.path,设置动态库的环境路径来加载,以及使用开启jna调试模式看日志。但是最终还是不行,我尝试过配置环境变量、开启jna调试、升级jna版本为5.4.0、断点调试、在调试的时候我都怀疑是不是Native.load是不是对win路径的写法有特殊要求。都不行!还有jre运行与系统位数不对等解决方法。
但是现象很奇怪的我的有个idea项目是可以运行的,独立打包出来就不行,我就开始怀疑java启动参数、环境变量是不是有问题。但是最终所有办法都试了就是不行。
最后在我无意的时候,在github的issues上看到了类似的问题。
https://github.com/java-native-access/jna/issues/725
里面有个国外小哥说
Please check that you have the Visual C++ Runtime 2010 64bit installed.
我心里想一万句xxx。准是这个问题没错了。系统环境问题。
最后我安装了VC++ Runtime 2010 64,gg这个问题就算解决了。终于愉快的去迎接下一个大问题了。

总结

历经艰险,终于解决了问题,但我想反思一下,为什么花费了那么多时间还没有解决?我觉得是异常的提示有问题异常中
not found in resource path这个意思就是找不到。但实际上不是,原因是dll无法被正常的加载,所以出现了问题。遇到问题要仔细分析。不然对人是一种打击。


版权声明:本文为mathcoder23原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。