一. 静态库
1. 生成
1. 文件:fileA.c fileB.c foo.h
# 将所有 .c 文件编译成 .o 文件
gcc -c fileA.c
gcc -c fileB.c
2. 文件:fileA.c fileA.o fileB.c fileB.o foo.h
# 使用 ar 命令所有”.o”文件生成静态库 c:创建库 r:函数加入到库 v :显示过程
ar crv libfoo.a fileA.o fileB.o
3. 文件:fileA.c fileA.o fileB.c fileB.o foo.h libfoo.a
2. 使用
# 在代码中添加头文件
#include "foo.h"
# 直接使用函数
int main()
{
fileA();
fileB();
return 0;
}
3.编译
# 编译程序
gcc -o main main.c -L. -lfoo
4. 加入到系统库中
# 将头文件的 foo.h 放入到
/usr/include
# 将生成的 libfoo.a 放入到
/lib
/usr/lib
# 在后续调用时可使用尖括号引用
#include <foo.h>
二. 共享库
1. 生成
1. 文件:fileA.c fileB.c foo.h
# 将所有 .c 文件编译成 .o 文件
gcc -c fileA.c
gcc -c fileB.c
2. 文件:fileA.c fileA.o fileB.c fileB.o foo.h
# 编译所有 .o 文件生成共享库
gcc -shared -fPIC -o libfoo.so max.o add.o
3. 文件:fileA.c fileA.o fileB.c fileB.o foo.h libfoo.so
2. 使用
# 在代码中添加头文件
#include "foo.h"
# 直接使用函数
int main()
{
fileA();
fileB();
return 0;
}
3.编译
# 编译程序
gcc -o main main.c -L. -lfoo
4. 加入到系统库中
# 运行时如果出错 可以将 .so 放入到
/lib
/usr/lib
# 临时测试可以使用 LD_LIBRARY_PATH 修改环境
LD_LIBRARY_PATH=.
export LD_LIBRARY_PATH
# 将头文件的 foo.h 放入到
/usr/include
# 将生成的 libfoo.a 放入到
/lib
/usr/lib
# 在后续调用时可使用尖括号引用
#include <foo.h>