We have this app that loads native library, and this library provides
native methods for us to call. On some phones (particularly the slower
ones), this causes a problem. An UnsatisfiedLinkError occurs whenever
(I think) the library is still being "loaded" and a method is called
prematurely.
Is there a way to handle this issue? Like checking if a library is already loaded.
Even on slower devices, the call to System.loadLibrary()
is very fast; but if your app runs multithreaded, or if the class that involves the static constructor is only loaded in response to some UI event - then there could be a race condition: some other classes that rely on the native library being present will cause a crash.
There is no prohibition of using the static constructor which calls System.loadLibrary()
for all classes that have native methods. You could see some warnings about native library being loaded multiply, but this does not have negative consequences.
Sometimes, we use custom Java code to extract the native libraries to files directory when the app is run for the first time, instead of relying on the system installer, which puts them into the lib directory. This should be done with extra care, and all activity (pun intended) should wait until extraction of the libs (typically from the assets folder of APK) is complete.
Another catch could be that for some devices, the name of your library may be used by a system library. In such case, System.loadLibrary()
will load the library from /system/lib and not from your app; but this can hardly explain the effect of 3 sec delay.