动态库和静态库的区别
静态库(库名的后缀 .a):
程序在编译链接时把库的代码直接加载到可执行文件中,程序运行的时候便不再需要静态库。。因为每个程序都要加载一次库文件,所以很浪费系统空间。
动态库(库名的后缀 .so):
程序在运行时才去链接动态库的代码,多个程序可共享使用库文件中的代码。因为不用在自己的可执行程序中加载库文件,只需要在进程地址空间的共享区加载一次即可,从而节省了内存和磁盘空间。
- 在Linux中,gcc默认生成的二进制可执行程序是动态链接的。
- 一个与动态库链接的可执行文件仅仅包含它用到的函数入口地址的一个表,而非外部函数所在目标文件的整个机器码。
- 在可执行文件开始运行前,外部函数的机器码由操作系统从磁盘上的动态库复制到程序内存中,这个过程称为动态链接(dynamic linking)
生成静态库
库的命名:lib+自定义名+.a/.so
- 前期准备:要链接自己的库实现的功能
///add.h///
#ifndef __ADD_H__
#define __ADD_H__
int add(int a,int b);
#endif //__ADD_H__
///add.c///
#include "add.h"
int add(int a,int b)
{
return a+b;
}
///sum.c///
#include <stdio.h>
#include "add.h"
int main()
{
int a=10;
int b=20;
printf("add(%d,%d)=%d\n",a,b,add(a,b));
return 0;
}
2. 生成完成操作的 .o 文件
gcc -c add.c -o add.o
3.将 .o 文件归档到自己的静态库中,并查看静态库目录列表中是否存在
ar -rc libsum.a add.o
ar -tv libsum.a
ar是gnu 的归档工具
r-代替,c-创建,t-列出静态库中的文件,v-详细信息
4. 链接刚生成的静态库,运行程序
gcc sum.c -L. -lsum
-L 指定库路径
-l 指定运行时链接库名
5. 我们发现测试目标文件生成后,即使删除静态库,程序照样可以运行。由此证明静态库已经加载到了程序中
生成动态库
-fPIC 表示产生位置无关码
shared 表示生成共享库格式
由add.c add.h add.o 共同生成动态库
运行动态库
使用动态库
对库的简单操作
查看C库:
sudo find /-name libc.*
查看库:
ls /use/local/lib64/
查看主程序依赖的库:
ldd main
查看主程序的链接方式:
file main
要使用自己的库则必须给别人提供
- .h头文件(包含方法)
- .so或.a 的库(包含实现过程)
动静态库就讲到这里啦,因为一般也没人会使用我们写的库,所以我只了解了一下动静态库的区别和生成原理,其他更深入的内容,博主就没有涉及了~
欢迎大家留言和博主讨论哦