在linux中,动态链接库的搜索路径需要使用LD_LIBRARY_PATH来指定。例如
export LD_LIBRARY_PATH=LD_LIBRARY_PATH:/your_lib_path
假如你是个懒蛋,so文件在jar包中,而且又不想在运行jar包之前输入其他命令,写其他脚本。
而是运行jar包的时候,复制so文件到tmp文件夹,动态的加载这个库。
但是,这样会报找不到库的错误。
因为java程序已经运行了,再export LD_LIBRARY_PATH添加tmp已经没有用了。
通过ProcessBuilder先设定好LD_LIBRARY_PATH,然后在新建一个Process,这个进程的动态库搜索路径就包含了tmp了。
例如在jar包中,App1是主类,App2从jar包里解压缩so库文件,并且加载,这时就不会报错了(可是为啥第一次执行的时候还是会报错,第二次就能找到了。)。
public class App1 { public static void main(String[] args) { ProcessBuilder pb = new ProcessBuilder(); pb.inheritIO(); String tmpStr = System.getProperty("java.io.tmpdir"); String sep = File.separator; pb.environment().put("LD_LIBRARY_PATH", tmpStr + sep); pb.command("java", "App2"); Process p; try { p = pb.start(); p.waitFor(); System.out.println("Bye!"); p.destroy(); } catch (Exception e) { e.printStackTrace(); } } }
ProcessBuilder - 用来解决java程序LD_LIBRARY_PATH的问题(动态解压缩so文件然后添加路径)
原文:https://www.cnblogs.com/zhsmtp/p/12070357.html