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 运行
经验分享 程序员 微信小程序 职场和发展