环境:AIX,JDK1.4
Hello.javapublic class Hello
{
   static{
        System.loadLibrary("Hello");
   }
   public native void testHello();
   public static void main(String[] args){
     Hello ins = new Hello();
     ins.testHello();
  }
}Hello.c#include <jni.h>
#include "Hello.h"
#include <stdio.h>
JNIEXPORT void JNICALL Java_Hello_testHello
  (JNIEnv *env, jobject obj)
{
        printf("Hello world!\n");
        return;
}生成动态库的命令: gcc -Wall -c Hello.c -I./ -I//usr/java14/include -I/usr/java14/include
 ld -G -bnoentry -brtl -berok Hello.o -o libHello.so运行Hello.class文件总是报错:
Exception in thread "main" java.lang.UnsatisfiedLinkError: testHello
        at Hello.main(Hello.java:9)
哪位大侠帮看看,急!!

解决方案 »

  1.   

    参考我的一篇文章试一下:(不过我是在linux下的)http://blog.csdn.net/huoyin/archive/2008/10/01/3006772.aspx
      

  2.   

    你生成的动态链接库放到java工程目录下了吗?
      

  3.   

    放在下面了。
    问了别人,问题已经解决了。把ld命令参数修改了就好了:ld -G -bnoentry Hello.o -o libHello.so -bexpall -lc但还是有个问题:
    场景如下:
    (------>表示调用符号)
    java程序------>jni动态库------>.so文件A------>.so文件B,现在刚解决了java程序------>jni动态库这一步,jni动态库------>.so文件A又报错了。
    这些程序在salories上都已经运行起来了。我估计还是编译链接时出问题了,但不知道问题在哪?
    附上其他两个.so文件的编译链接命令://.so文件B
    gcc -fpic -shared  ddd.c -o libddd.so
    //.so文件A
    gcc -c -fpic call_1.c
    gcc -c -fpic call_2.c
    gcc -fpic -shared  Caller.c -o libcaller.so call_1.o call_2.o libddd.so大侠们,继续关注一下啊
      

  4.   

    运行时
    java -Djava.library.path=. Hello加入你的libhello.so的位置,应该就好了~