今天遇到了一个问题,我写的动态链接库在编译链接的时候都没有问题:
gcc test.c -o test -L ../lib/ -lerr_handle -g
但是在运行时却报错:
./test: error while loading shared libraries: liberr_handle.so: cannot open shared object file: No such file or directory
明明我已经通过gcc的-L和-l参数指定了要去哪找动态链接库了,但是为什么在运行的时候还是找不到呢?事实上在编译过程中,-L 和 -l 指定的是编译时要依赖的库文件和路径,但是动态库是在运行时才加载的,系统会到默认的路径(比如 /usr/lib)下去查找动态库,而我们并没有向系统给出动态库加载时要去哪里查找动态库的位置,所以会出现找不到的问题!
那么如何解决这个问题呢?如下三种方法:
- 通过export修改LD_LIBRARY_PATH环境变量指定要查找库的位置
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:your/lib/path
- 通过ldconfig命令后加要查找的位置作为参数
- 链接时语句后面添加如下命令:-Wl,-rpath=my/third/party/lib/path
解释一下第三种的方法中-Wl和-rpath的意义:
- -Wl:表示编译器将后面的参数传递给链接器ld
- -rpath:添加一个文件夹路径作为运行时库的搜索路径,在运行链接时,会优先搜索-rpath的路径,再去搜索LD_RUN_PATH的路径
第三种方法在编译的时候同时指定了加载时要查找的位置,是比较好的方法;