Я использую Ubuntu 10.10
Так я и сделал.
Hello.java :
class Hello {
public native void sayHello();
static { System.loadLibrary("hellolib"); }
public static void main(String[] args){
Hello h = new Hello();
h.sayHello();
}
}
Затем я выполнил следующие команды:
dierre@cox:~/Scrivania/provajni$ javac Hello.java
dierre@cox:~/Scrivania/provajni$ javah -jni Hello
Я получил Hello.class
и Hello.h
.
Hello.h :
/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class Hello */
#ifndef _Included_Hello
#define _Included_Hello
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: Hello
* Method: sayHello
* Signature: ()V
*/
JNIEXPORT void JNICALL Java_Hello_sayHello
(JNIEnv *, jobject);
#ifdef __cplusplus
}
#endif
#endif
Затем я создал Hello.cpp :
#include <jni.h>
#include "Hello.h"
#include <iostream>
using namespace std;
JNIEXPORT void JNICALL Java_Hello_sayHello (JNIEnv *env, jobject obj) {
cout << "Hello World!" << endl;
return;
}
И теперь часть, где, как мне кажется, я облажался.Я был вдохновлен этим руководством ( Компиляция раздела динамической библиотеки или библиотеки общих объектов ) :
dierre@cox:~/Scrivania/provajni$ gcc -I"/usr/lib/jvm/java-6-sun/include" -I"/usr/lib/jvm/java-6-sun/include/linux" -o hellolib.so -shared -Wl,-soname,hello.so Hello.cpp -static -lc
, который генерирует файл hellolib.so
Но когда я пытаюсь запустить его с java Hello
, у меня появляется эта ошибка:
Exception in thread "main" java.lang.UnsatisfiedLinkError: no hellolib in java.library.path
at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1734)
at java.lang.Runtime.loadLibrary0(Runtime.java:823)
at java.lang.System.loadLibrary(System.java:1028)
at Hello.<clinit>(Hello.java:4)
Could not find the main class: Hello. Program will exit.
Я даже пробовал это:
LD_LIBRARY_PATH=`pwd`
export LD_LIBRARY_PATH
безрезультатно.
Я знаю, что делаю что-то чрезвычайно глупое, но я не могу понять, что это такое.Динамическая библиотека генерируется с опцией -shared, не так ли?
Обновление # 1
Я попытался static { System.load("/home/dierre/Scrivania/provajni/hellolib.so"); }
, чтобы увидеть, работает ли это, но сейчас:
Exception in thread "main" java.lang.UnsatisfiedLinkError: /home/dierre/Scrivania/provajni/hello.so: /home/dierre/Scrivania/provajni/hello.so: undefined symbol: _ZSt4cout
at java.lang.ClassLoader$NativeLibrary.load(Native Method)
at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1803)
at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1699)
at java.lang.Runtime.load0(Runtime.java:770)
at java.lang.System.load(System.java:1003)
at Hello.<clinit>(Hello.java:4)
Обновление # 2 Хорошо, для решения проблемы Обновление # 1 Мне пришлось использовать g++
вместо gcc
, очевидно.По-прежнему возникают проблемы с использованием метода load
.Я не могу сказать, что это правильный путь.