在Linux C/C++中,使用库的方式有3中:
1.静态库
1).创建object文件:
gcc -c lib_c.c -o mylib.o
(the -c option says not to run the linker. )
输出为lib_h.o
2).创建后缀为.a的静态库:
ar rcs mylib.a mylib.o
其中ar(archive)中的rcs的意思是:r表明将模块加入到静态库中,c表示创建静态库,s表示生产索引。
输出为mylib.a
(使用objdump -D mylib.o和objdump -D mylib.a后使用beyondCompare比较之后,发现.o与.a文件内容是一样的)
3).使用mylib.a:
gcc -static use_lib.c -L. mylib.a -o testLib
(注意1:参数-static表示使用静态库方式链接,如果没有-staic将使用共享库方式链接。-L.表示将当前目录加入到库搜索路径。)
(注意2:使用ldd testLib,如果是静态库方式链接,输出为:not a dynamic executable;如果是共享库则不然。通过比较,我们会发现以静态库方式编译输入文件会大很多)
4). 查看静态库符号:
nm mylib.a
输出为:
mylib.o:
U puts
0000000000000000 T testLib
U表示在库中被调用,但并没有在库中定义(表明需要其他库支持),T表示是库中定义的函数。
1.静态库
1).创建object文件:
gcc -c lib_c.c -o mylib.o
(the -c option says not to run the linker. )
输出为lib_h.o
2).创建后缀为.a的静态库:
ar rcs mylib.a mylib.o
其中ar(archive)中的rcs的意思是:r表明将模块加入到静态库中,c表示创建静态库,s表示生产索引。
输出为mylib.a
(使用objdump -D mylib.o和objdump -D mylib.a后使用beyondCompare比较之后,发现.o与.a文件内容是一样的)
3).使用mylib.a:
gcc -static use_lib.c -L. mylib.a -o testLib
(注意1:参数-static表示使用静态库方式链接,如果没有-staic将使用共享库方式链接。-L.表示将当前目录加入到库搜索路径。)
(注意2:使用ldd testLib,如果是静态库方式链接,输出为:not a dynamic executable;如果是共享库则不然。通过比较,我们会发现以静态库方式编译输入文件会大很多)
4). 查看静态库符号:
nm mylib.a
输出为:
mylib.o:
U puts
0000000000000000 T testLib
U表示在库中被调用,但并没有在库中定义(表明需要其他库支持),T表示是库中定义的函数。
测试代码:
lib_h.h
void testLib();
#include <stdio.h>
#include "lib_h.h"
void testLib()
{
printf("hello, I'm lib, welc