前言
上一节讲了 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\n",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 运行