linux静态库 .a ===== win 静态库 .lib
linux动态库 .so ==== win动态库 .dll
(1)----静态库生成过程:
-- 原材料 :源码.c文件或.cpp文件
----第一步:将.c文件生成.o文件:gcc *.c -c
----第二步:将.o文件打包: ar rcs 静态库名字 *.o文件
(静态库名字 = libmytest.a):三部分,前缀,名字,后缀
-----ar rcs libmytest.a *.o
查看库内容 nm libmytest.a
查看app内容 file app
到此,一个静态库就创建成功了。
(2)------静态库的使用:
调用静态库文件假设为libtest.c
gcc -I ./include -L ./lib -lmytest
-L : 大l 指定库的路径
-l :小l 指定库的名字(去掉前缀和后缀)
-I :大i :指定头文件路径
如果想指定生成的可执行文件的名字,用-o指定文件名,gcc -I ./include -L ./lib -lmytest -o app
(3)-------动态库的产生:
----原材料:源代码.c/.cpp文件
-----第一步:将源文件生成.o文件: gcc *.c -c fpic(fPIC)
-----第二步:打包: gcc -shared *.o -o libmytest.so
(4)-----动态库的使用:
同静态库:gcc test.c -c -I./include -L ./lib -lmytest -o app
运行app报错:mytest not found
(5)-----动态库无法加载原因:命令ldd app看到libmytest.so显示找不到此动态库。
动态链接器ld_linux_x86_64.so查找动态库先后顺序:
1. LD_LIBRARY_PATH,环境变量
2. /etc/ld.so.cache文件列表
3. /lib
4. /usr/lib
当以上4个位置都检查不到那个动态库文件时候就会报错!
(6)-----解决办法:
---------1, 将.so文件拷贝到/lib或者/usr/lib下(不推荐,可能会和已有的库名字冲突而覆盖掉原来文件)。
--------2, 修改LD_LIBRARY_PATH环境变量(推荐)
------临时修改(当前终端有效):
export LD_LIBRARY_PATH = 动态库路径 : $LD_LIBRARY_PATH
--------永久修改
===用户级别:(当前用户生效)
修改~/.bashrc文件,完成后重启终端或者source ~/.bashrc
===系统级别:(所有用户生效)
修改./etc/profile文件,安成后重启终端或者source ./etc/profile
source可用.代替。
--------------3. 修改ld.so.cache列表
将动态库的绝对路径写入到/etc/ld.sl.conf中,
完成后执行 ldconfif -v(-v参数展示终端输出内容)
(7)----静态库动态库对比:
====静态库将.a文件中相关的.o文件与调用这个静态库编译后的.o文件一起组成可执行文件。
1. 由于静态库已经被打包进可执行程序文件中,所以加载起来会速度很快,发布程序不需要提供静态库,移植方便。这同时就导致了更新发布复杂。同时静态库浪费系统资源,消耗内存。
2. 程序一开始运行,静态库就被加载到内存了。
====动态库是没有打包进可执行程序的,只是记录了用到哪个库里的哪个函数,运行程序的时候动态库也不会被加载,当程序调用动态库里面的函数的时候,动态库才会被加载到内存。
程序运行之前先检查动态库是否存在,通过动态链接器ld _linux_x86_64.so检查器检查动态库是否存在。