Forums Register Login

Undefined reference in JNI

+Pie Number of slices to send: Send
Hi,I was trying to embedd some java code in C and needed to invoke the JVM.But i keep getting an error - 'undefined reference to 'JNI_CreateJavaVM''.I'm not sure what i'm doing wrong.
Here is the program and the command i use to run it.
(the following program is a sample program i took off the web,but it shows me the same error)I'd greatly appreciate it if someone could help me here.I'm almost done pulling all my hair out.
I'm programming on linux and have jdk1.2.2 installed.
I think the problem i might have is because of my libjava.so and libjvm.so and the like,but i'm not sure exactly tho.
HELP!!
#include
#ifdef _WIN32
#define PATH_SEPARATOR ';'
#else /* UNIX */
#define PATH_SEPARATOR ':'
#endif
#define USER_CLASSPATH "." /* where Prog.class is */
main() {
JNIEnv *env;
JavaVM *jvm;
JDK1_1InitArgs vm_args;
jint res;
jclass cls;
jmethodID mid;
jstring jstr;
jobjectArray args;
char classpath[1024];

/* IMPORTANT: specify vm_args version # if you use JDK1.1.2 and beyond */
vm_args.version = 0x00010001;
JNI_GetDefaultJavaVMInitArgs(&vm_args);
/* Append USER_CLASSPATH to the end of default system class path */
sprintf(classpath, "%s%c%s",
vm_args.classpath, PATH_SEPARATOR, USER_CLASSPATH);
vm_args.classpath = classpath;
/* Create the Java VM */
res = JNI_CreateJavaVM(&jvm,&env,&vm_args);
if (res < 0) {<br /> fprintf(stderr, "Can't create Java VM\n");<br /> exit(1);<br /> }<br /> cls = (*env)->FindClass(env, "Prog");
if (cls == 0) {
fprintf(stderr, "Can't find Prog class\n");
exit(1);
}
mid = (*env)->GetStaticMethodID(env, cls, "main", "([Ljava/lang/String <http://www.javaranch.com/ubb/wink.gif>; V");
if (mid == 0) {
fprintf(stderr, "Can't find Prog.main\n");
exit(1);
}
jstr = (*env)->NewStringUTF(env, " from C!");
if (jstr == 0) {
fprintf(stderr, "Out of memory\n");
exit(1);
}
args = (*env)->NewObjectArray(env, 1,
(*env)->FindClass(env, "java/lang/String"), jstr);
if (args == 0) {
fprintf(stderr, "Out of memory\n");
exit(1);
}
(*env)->CallStaticVoidMethod(env, cls, mid, args);
(*jvm)->DestroyJavaVM(jvm);
}

Command:
gcc -I -L-ljava invoke.c
The java file is a simple program(Prog.java) which just prints something to the screen.
Anyhelp will be greatly appreciated it.
..Frankie
+Pie Number of slices to send: Send
Hi everybody,like i guessed the problem was due to my not loading the shared libraries properly(i.e.libjvm.so,libjava.so,libhpi.so)
.I load them explicitly when i compile them and it compiles fine.But when i try to run the program it shows an error saying that it cannot load the shared libraries.Here's the screen command and output:
gcc -L/home/frankie/Java/JNI/Ex3 -ljvm
-L/home/frankie/Java/JNI/Ex3 -ljava
-L/home/frankie/Java/JNI/Ex3 -lhpi invoke.c -o invoke
now when i run invoke:
error while loading shared libraries:libjvm.so:cannot load shared object file:no such file or directory

Any suggestions ??I know i'm screwing up with the shared libs but where should they all be??and am i loading them right??
--Frankie
+Pie Number of slices to send: Send
It sounds as though you need to provide the JVM with the same classpaths to your shared libraries as you used when you compiled. Since the compiler and jvm use their own classpath settings you must make external lib's available for both operations. For instance you can run the program like so (example on a solaris system)
java -classpath $CLASSAPTH:path/to/shared/libs MyApp
This is my guess anyway. Hope this helps.
Sean
[This message has been edited by Sean MacLean (edited October 02, 2001).]
+Pie Number of slices to send: Send
You're right.The program had to load the library files at runtime also, and so i had to specify the path in the library load file-
'ld.so.conf'.I did that and it runs fine,apart from the fact that my program isn't right..:-)but i'll take em on one at a time.Thanks a bunch.!
roses are red, violets are blue. Some poems rhyme and some are a tiny ad:
a bit of art, as a gift, the permaculture playing cards
https://gardener-gift.com


reply
reply
This thread has been viewed 2763 times.
Similar Threads
JNI : Creating a JVM
Undefined reference in JNI
JNI : undefined reference to JNI_CreateJavaVM()
Invoking JVM through C++ code
problem of C++ Call java with JNI
More...

All times above are in ranch (not your local) time.
The current ranch time is
Apr 16, 2024 08:31:53.