Is there a platform-independent Java statement to load a native library from a different directory than the Java source code is in? I would like to use something like this:
public class HelloWorld {
static {
System.loadLibrary("../some_project/HelloWorld");
}
public static native void print();
}
The problem is that System.loadLibrary() doesn’t support directory separators in the pathname argument. Also, System.load() unfortunately requires an absolute pathname, which not only means I can’t specify a relative directory as above (which I would like to do), but it also requires the argument to include, for example, the preceding “lib” and “.so” extension on the JNI library name on a Linux system.
Is there a standard way of dealing with this? If possible, I would like to avoid writing a bunch of platform-dependent Java code just to construct the correct JNI library name.
I believe you’re looking for System.mapLibraryName, which is the method typically used by ClassLoader.findLibrary implementations. For example:
This will use
libHelloWorld.soon Linux andHelloWorld.dllon Windows. Be aware that some operating systems support multiple extensions, and mapLibraryName can only support one, by design. The ones I’m aware of are MacOS (.dylibprimarily and.jnilibfor legacy) and AIX (.aand.so).