静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库。编译之后程序文件大,但加载快,隔离性也好。
动态库在程序编译时并不会被连接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需要动态库存在。多个应用程序可以使用同一个动态库,启动多个应用程序的时候,只需要将动态库加载到内存一次即可。
编译动态库:
-shared 该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成弱连接W类型的导出符号),不用该标志外部程序无法连接。相当于一个可执行文件
-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
-L.:表示要连接的库在当前目录中
-ltest:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称
配置库位置:
LD_LIBRARY_PATH:这个环境变量指示动态连接器可以装载动态库的路径。
当然如果有root权限的话,可以修改/etc/ld.so.conf文件,然后调用 /sbin/ldconfig来达到同样的目的,不过如果没有root权限,那么只能采用输出LD_LIBRARY_PATH的方法了。
ldd命令可以查看可执行文件依赖的库文件。
root@xxj-VirtualBox:~/interview# ldd gmedian
linux-vdso.so. => (0x00007fff88c71000)
libstdc++.so. => /usr/lib/x86_64-linux-gnu/libstdc++.so. (0x00007f4013945000)
libgcc_s.so. => /lib/x86_64-linux-gnu/libgcc_s.so. (0x00007f401372f000)
libc.so. => /lib/x86_64-linux-gnu/libc.so. (0x00007f4013368000)
libm.so. => /lib/x86_64-linux-gnu/libm.so. (0x00007f4013062000)
/lib64/ld-linux-x86-.so. (0x00007f4013c5f000)