Linux下库的制作(静态库与共享库)
库中实际上就是已编译好的函数代码,可以被程序直接调用。
Linux下的库一般的位置在/lib
或者/usr/lib
中
静态库
静态库是复制拷贝到调用函数中的,函数运行的时候不再需要静态库,因为静态库是在链接的时候加进去的,所以当函数运行的时候,源库的改变对运行中的函数造成不影响。随之而来,当静态库升级之后,每一个调用静态库的程序都需要重新编译。
特点:
- 链接静态库的时候,会把库中的相关代码拷贝到可执行文件中
- 程序运行时不再需要静态库
- 程序运行时不需加载库,运行速度快
- 因为库中相关代码是拷贝到可执行文件中,所以占用了更多的磁盘和内存空间
- 静态库升级之后需要重新编译链接
1.制作库的代码框架:
vim static_test.c
gcc -c static_test.c -Wall #生成 .o 文件
ar crs libstatic_test.a static_test.o #静态库名字就是 static_test.a
#注意: libxxx.a 是创建静态库的格式 其中 xxX.o 就是静态库的名字
还可以用nm libstatic_test.a
来查询静态库中的符号信息,也就是函数名称:
2.调用库:
在调用库的函数中要声明调用的函数,不然会报错,然后在编译链接的时候加上静态库:
gcc -o test test.c -L. -lstatic_test
#注意:gcc -o test test.c -L.(-L 是添加库搜索路径,这里库是在当前文件夹的) -l(指定要链接库名字xxx)
#库名是static_test 库文件名是 static_test.a
编译器默认链接C库
3.执行:
通过调用静态库中的Hello函数来输出“Hello World”:
共享库
特点:
- 共享库在链接的时候,仅仅是记录一下用到了哪个库中的哪个函数,并不复制库中相关代码
- 多个程序可以同时调用一个共享库
- 程序在运行的时候来加载共享库
- 程序体积变小,程序本身没有包含库中的代码
- 共享库升级之后,无需重新编译程序
1.生成位置无关代码
gcc -c -fPIC share_test.c -Wall
-fPIC
表示生产的目标文件是位置无关代码,即可以放在程序的任何地方执行。
2.创建共享库文件
gcc -shared -o libshare_test.so.1 share_test.o
-shared
来指定gcc创建一个共享库文件
libshare_test.so.1
就是共享库文件名,.so
表示是一个共享库文件,共享库文件命名格式为libxxx.so.x
最后的x是版本控制,最后面包含的是目标文件,可以是多个目标文件
3.创建链接文件
为了编译器能够找到相应的共享库,需要一个链接文件:
ln -s libshare_test.so.1 libshare_test.so
第一个是目标文件,第二个是符号链接符号,其命名规则是libxxx.so
(注意:链接文件没有版本控制)。链接文件相当于一个指针,指向共享库文件。
4.编译并链接共享库
gcc -o test test.c -L. -lshare
-L
指定共享库的路径
-lxxx
来表示链接文件
当静态库和共享库的链接文件名字一样时,优先使用共享库,但是也可以使用-static
来指定静态库。