静态库和动态库的制作

一、什么叫做库:

库:二进制的程序,能被操作系统载入内存中执行

二、Linux下的库有两种:静态库和共享库(动态库),二者的不同点在于代码载入的时刻不同。

A、静态库在程序编译的时候并会被连接到目标代码中,程序运行时将不再需要该静态库,因此体积较大

B、动态库在程序编译的时候并不会被连接到目标代码中,而是在程序运行时被载入,因此程序运行时还需要动态库存在,因此目标代码体积小。

1、静态库的制作

A、创建静态库的源代码 fun.c

B、将源代码编译成.o文件

gcc -c fun.c -o fun.o

gcc -c -o fun.o fun.c

C、将.o文件生成静态库

ar crs libfun.a fun.o(ar是生成静态库的命令,crs是选项)

ar crs的谐音是爱人才认识

静态库的命名规则:libxxx.a xxx表示库名

D、编写测试代码并编译(-L 指定路径 –lfun指定库)

gcc main.c -o main -lfun -L. 库在当前目录

gcc -o main main.c -L. –lfun 一样的效果

gcc main.c -o main -lfun -L.. 库在上一级目录

gcc main.c -o main -lfun -L ../auto_lib/ 库在上一级目录的auto_lib路径下面

E、执行 ./main

2、动态库的制作

A、编写库的源代码 fun.c

B、将其编译成.o文件

gcc -fPIC -Wall -c fun.c

C、将.o文件生成动态库

gcc -shared -fPIC -o libfun.so fun.o

D、编写测试代码main.c 并编译

gcc -o main main.c -L. –lfun

备注:此时执行的话会出现这样的错误提示

静态库和动态库的制作
原因是动态库没有装载,解决这个问题有3种方法:

<1> 将制作的动态库放在 /lib或/usr/lib

sudo mv libfun.so /lib/

sudo mv libfun.so /usr/lib/

然后执行./main 结果如下

静态库和动态库的制作

静态库和动态库的制作

<2>将制作的动态库的当前路径加入库的配置文件中
配置文件查找当前路径

进入配置文件 sudo vi /etc/ld.so.conf.d/libc.conf

添加路径

静态库和动态库的制作
使配置生效 sudo ldconfig

<3>将路径加入环境变量中(此方法不靠谱)

查看环境变量中有没有值

echo $LD_LIBRARY_PATH

在环境变量中加上库所在的路径

export LD_LIBRARY_PATH=/home/leo/IO/16073/auto_lib

使配置生效 sudo ldconfig

3、库的升级(后台修改库,升级系统)

<1> 修改库的源代码

静态库和动态库的制作
将其编译生成.o文件

gcc -fPIC -Wall -c fun.c

将.o文件生成动态库

gcc -shared -fPIC -o libfun.so fun.o

执行 ./main 看效果

静态库和动态库的制作
升级成功,以上这些就是静态库和动态库的知识了

附件知识:

● -shared:指定生成动态链接库。

● -static:指定生成静态链接库。(创建静态库我们一般用ar命令,它将很多.o转换成.a)

● -fPIC:表示编译为位置独立的代码,用于编译共享库。目标文件需要创建成位置无关码,概念上就是在可执行程序装载它们的时候,它们可以放在可执行程序的内存里的任何地方。

● -L.:表示要连接的库在当前目录中。

● -l:指定链接时需要的动态库。编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称。

● -Wall:生成所有警告信息。

● -ggdb:此选项将尽可能的生成gdb的可以使用的调试信息。

● -g:编译器在编译的时候产生调试信息。

● -c:只**预处理、编译和汇编,也就是把程序做成目标文件(.o文件)。

● -Wl,options:把参数(options)传递给链接器ld。如果options中间有逗号,就将options分成多个选项,然后传递给链接程序。
————————————————
版权声明:本文为****博主「华清远见嵌入式学院」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.****.net/farsight2009/article/details/54847506