JNI java.lang.UnsatisfiedLinkError

本文详细介绍了在Windows环境下使用MyEclipse+CDT8.0+MinGW编译器进行JNI开发时遇到的两个常见错误:java.lang.UnsatisfiedLinkError,并提供了相应的解决方法。通过设置正确的java.library.path环境变量和正确使用gcc编译参数,可以有效地解决这些问题,确保开发顺利进行。

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

 

最近要用到JNI所以先练下手,因为项目是要在linux环境下开发,但是我自己的机子上环境还不全,所以就先用WINDOWS来测试了,其实原理和linux是差不多的。

 

myeclipse中安装了CDT8.0环境,配合MinGW编译器

 

按照网上的例子写个helloWorld了,就是这么个helloWorld 害我搞一下午。

错误1: java.lang.Unsatisfie.lang.UnsatisfiedLinkError no XXXXX in java.library.path

这个错误一般是找不到dll文件

执行下这个 可以看看 System.out.println(System.getProperty("java.library.path")); 其实就是我们设置的path 环境变量里的东西或者有其他系统的设置。(在windows cmd下 输入path 或者 set 都可以看)。看了这个以后你就知道这个dll或者so文件放哪里他是可以找到了,当然最简单的放这个java文件所在的目录了或者他上层目录,一般是和java src目录同层目录就好了,你看下java.library.path 中有个点号(.) 就表明是当前工作目录的意思,所以肯定在工程目录下有个位置。这个错误一般比较好解决。

错误2:java.lang.UnsatisfiedLinkError: XXXclass.XXXmethod()

这个错误是 在这个dll里找不到方法的声明,(搞了一下午害我差点装VC了,还借用到了dll查看工具)

网上说是@符号的问题 ,解决方法是用gcc 编译的时候指定参数

第1种方法:

gcc -Wl,--kill-at -shared -o jnihello.dll Native.c

这种方法生成不带@的函数声明

第2种方法:
gcc -Wl,--add-stdcall-alias -shared -o jnihello22.dll Native.c

这种方法会生成2个函数声明,一个是带@的 一个是不带@的。

第3种方法:

在你的本地方法的头文件中中的函数前面加上下划线,比如以前是

JNIEXPORT void JNICALL Java_TestNative_Hello (JNIEnv * , jobject );

现在改成

JNIEXPORT void JNICALL _Java_TestNative_Hello (JNIEnv * , jobject );

同时你的实现的cpp文件或者c文件里的函数头也要一致 前面有下划线。

如果你需要查看dll的导出函数声明可以用以下2个工具

1: dllexp

2:Anywhere PE Viewer

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值