linux的静态库和动态库制作
前言
上一节讲了 feof ferror clearerr 函数 并且fgetc 的返回值和feof 都是来用来 判断是否到文件尾部的 只不过返回值不一样 ferror 用来判断读写是否错误 clearerr 清除流错误。
一 静态库的原理
lib是固定前缀和.a是固定后缀 xxx是目标文件名 需要自己运行前 需要创建 c文件 但是空间就变大了这是缺点。
1 静态库制作
1 创建 两个源文件 一个作为 源文件 一个目标文件
一个目标文件 sub.c
int sub(int x,int y) { return x-y; }
一个源文件 main.c
#include<stdio.h> int main() { int x=11; int y=1; int f; f = sub( x, y); printf("%d ",f); return 0; }
2 编译生成: 用c文件 目标o文件
gcc sub.c -c -o sub.o
c文件和o文件生成的时间是不一样的。
3 生成 静态库
ar -cr -o libsub.a sub.o ar 是前缀 -cr -o :插入 o文件 进入静态库 (.a结尾就是静态库)
4 把目标文件链接到源文件
gcc main.c -L. -lsub -o main main.c 源文件 -L. 查找 -lsub 把目标文件链接到main.c 并且生成 main 可执行文件
注意
gcc main.c -L. -lsub -o main ***sub:指的是调用的c目标文件名 1 不是 vi 创建的 sub.c 的名字 2 而是 int sub(int x,int y)的函数名 3 注意函数名 和 库名 要一致 (要不然 出现的错误 千万别去试着解决 因为这是一个坑 会导致你静态库最后不可以编译)
1 动态库制作
rm sub.o 删除 静态库生成的o文件 1 gcc sub.c -c -o sub.o :用sub.c 生成调用的sub.o
c 和 o文件 生成的时间是不一样的。
2 gcc -fpic -shared -o libsub.so sub.o 生成so 动态库文件 并且临时调用sub.o
3 gcc main.c -L. -lsub -o main 编译 main.c 把 sub 往里面链接 并且生成 main
不能执行 main 需要 把 动态库 移动 到 /usr/lib 里面 。
1 先放到 /usr/lib 里面 2 再次编译 3 运行