Hadoop下进行JNI编程遇到的问题

本文详细阐述了在使用Java与JNI进行集成时遇到未定义方法错误的原因及解决办法,通过修改C文件中的宏定义,确保方法在调用前已被正确定义,从而实现Java和C代码的成功集成。

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

环境:

Ubuntu Server12.04

Hadoop1.2.1

gcc 4.6.3

JDK 1.7_51

hadoop@grc:~/jni$ gcc -fPIC -shared -o libMyJni.so MyJni.c -I. -I/home/hadoop/jdk1.7.0_51/include -I/home/hadoop/jdk1.7.0_51/include/linux
hadoop@grc:~/jni$ java TestJni
Exception in thread "main" java.lang.UnsatisfiedLinkError: TestJni.print(Ljava/lang/String;)V
	at TestJni.print(Native Method)
	at TestJni.main(TestJni.java:8)
hadoop@grc:~/jni$ echo $LD_LIBRARY_PATH
.
hadoop@grc:~/jni$ java -Djava.library.path=. TestJni
Exception in thread "main" java.lang.UnsatisfiedLinkError: TestJni.print(Ljava/lang/String;)V
	at TestJni.print(Native Method)
	at TestJni.main(TestJni.java:8)

问题如上,路径找到,编译没有问题,但是还是会报错。后来找到原因,

hadoop@grc:~/jni$ vim MyJni.c


图中红色框标志表示的意思是如果没有定义 _Included_TestJni就做里面的事,而_Included_TestJni在头文件MyJni.h 中已经出现了的,所以到 这个 C 文件里面 是已经定义过的,所以在C 文件里面是不会执行 这段宏定义里面的内容的,也就找不到方法了。解决方法是将红色框中的内容删除,再执行java TestJni即可成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值