在android JNI (1) 中,生成了一个libhello.so, 将libhello.so 使用adb push到模拟器的/system/lib中,修改文件权限为可读,之后运行Java上层应用。当运行到system.loadlibrary("hello")时,系统屏幕出现弹出窗口,并且结束了虚拟机的运行。使用adb logcat获取log, 错误部分的log为:
D/dalvikvm( 597): LOADING path /system/lib/libFnord.so 0x4006c4f8
I/dalvikvm( 597): Unable to dlopen(/system/lib/libFnord.so): Cannot find library
同时虚拟机还在java层抛出UnsatisfiedLinkError异常。
起初以为是libhello.so 位置放错了,或者libhello.so没有读的权限。但是确认后排除了这两种可能。
而后使用android strace来trace系统调用,strace 需要自行安装。具体使用方式在Java代码调用system.loadlibrary前使应用sleep, 或者用一个button click来触发加载。运行java应用,使用adb shell ps查询此应用的pid. 再将此pid attach到strace中, 使用 adb shell strace -p pid. 点击button, 触发system.loadlibrary加载Native动态库,可以得到strace 信息:
stat64("/system/lib/libhello.so", {st_mode=S_IFREG|0666, st_size&#