Linux动态库和静态库

1,手动制作静态库

1,如何形成静态库文件

做库时,头文件(.h)必须暴露,源文件(.c)必须隐藏。

操作:将需要形成库的文件编译成.o文件:

然后用指令:ar -rc libmy_stdio.a my_stdio.o my_string.o

其中,如果形成库文件前缀必须是lib,后缀必须是.a,后面可以加版本号。

这时候就可以把头文件和库文件交给另外一个人使用。

2,如何使用静态库

a,在系统层面导入库文件

首先拿到别人给的头文件和库文件,我们需要去系统路径下安装别人给的头文件和库文件:

安装头文件:sudo cp*.h /usr/include/

安装库文件:sudo cp libmy_stdio.a /lib64/

这个时候在c文件里包头文件就可以找得到库文件:

下面编译一下利用别人库函数的文件:

这个时候发现会报错,因为gcc只认自己的标准库,我们写的库属于第三方文件,gcc不认识,这时候要让gcc找到可以用指令:

gcc main.c -l my_stdio(注意!!!这里要去掉库文件的前缀和后缀)

可以看到这时候编译成功!所以我们学到了gcc的一个新指令 -l,引入指定名称的第三方库名称

b,如果头文件和库文件在同一目录下怎么使用

我们先把之前我们导入系统中库文件删除:

rm /usr/include/my_*

rm /lib64/libmy_stdio.a

这时我们用gcc main.c -o main会发现程序无法编译:

可以看到系统根据c中写的头文件找不到库文件,此时在与它同名文件夹下有库函数文件。

这时用gcc main.c -o mian -lmy_stdio会发现也不行:

所以得出一个结论,gcc在查找静态库时不会在当前路径下查!

这个时候可以引入gcc的另一个指令:-L(告诉编译器,编译时查找库在指明的路径下找)

操作:gcc main.c -o main -L. -lmy_stdio

这时成功在同文件下使用静态库

c,如何封装Makefile和怎么发布静态库

首先完成.o文件的编译,然后形成库文件:

再将c文件依次编译成.o文件:

这样就可以自动形成库:

那么我们怎么发布?

这里引用一个小知识,再makefile中也是可以调用系统接口的:

这个时候就可以将写好的stdc压缩然后发给别让人用。那么假设我就是那个别人,那么我该怎么用别人打包好的库文件?

gcc指令中-I可以去指定路径下寻找头文件:

gcc main.c -I stdc/include -Lstdc/lib -lmy_stdio

2,如何手动制作动态库

1,如何形成动态库文件?

在前面章节中已经了解了静态库怎么创建,那么动态库和静态库的创建方式类似,我们直接在makefile中修改:(注意,动态库的后缀是.so)

gcc中加入-shared,可以告诉gcc不要形成可执行程序,帮我形成so库

这个时候make一下:

可以看到里面多了一个库函数文件,使用方法就是和之前一样把头文件和库文件分别拖进系统中的include和lib64文件夹中,就可以直接:

gcc main.c -lmy_stdio就可以直接运行这里就不做展示。

2,如何使用动态库

a,当动态库与main .c同文件

gcc main.c -o main -L. -lmy_stdio

讲一个系统指令:ldd,可以用来查可执行程序依赖哪些程序

可以看到main可执行程序依赖这个库文件,

如果把库删了:

就会显示找不到库文件。

3,发布动态库

流程和静态库一样:

但是这个时候gcc main.c -o main -I stdc/include -Lstdc/lib -lmy_stdio

会发现形成的main执行不了:

会发现他的ldd为空,这时因为在main运行的时候与gcc没有关系,gcc找到了链接文件不代表可执行文件找到了,os要加载你对程序,但是系统找不到动态库。

4,如何给系统指定路径找动态库

1,拷贝到默认路径下(前面已强调多次)

2,建立软链接:

sudo ln -s /路径/库名 /lib64/同名.so就可以建立软链接:

这时就可以运行程序。

3,Linux系统中,os可以根据环境变量查动态库

这个时候可以用:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH: +路径也可以:

如果想永久加env可以vim .bash.src中加入export ....

4,讲路径写到.conf文件里

touch /etc/ld.so.conf.d/2024.conf

这时将库的路径写道2024.conf中:

然后需要用到指令ldconfig加载一下:

其中1方法和3方法比较常用,如果同时提供了so a文件呢?

gcc,g++会默认使用动态库,如果需要他只用静态库,可以加**-static**

这时去掉路径中的.so和-static:

可以跑?为什么?

如果只提供静态库,但是链接方法是静态库请见下篇分晓。

5,原理上理解动态库

我们知道,在堆区和栈区直接有一个共享区:

进程在执行库的方法,是在自己的地址空间中跳转运行

然后动态库他是从磁盘加载到内存中通过页表的映射到共享区给代码使用

这个时候如果有其他程序也需要调用这个库,就直接从页表映射到内存中找库:

相关推荐
watermelonoops1 分钟前
Deepin和Windows传文件(Xftp,WinSCP)
linux·ssh·deepin·winscp·xftp
woshilys33 分钟前
sql server 查询对象的修改时间
运维·数据库·sqlserver
疯狂飙车的蜗牛1 小时前
从零玩转CanMV-K230(4)-小核Linux驱动开发参考
linux·运维·驱动开发
恩爸编程2 小时前
探索 Nginx:Web 世界的幕后英雄
运维·nginx·nginx反向代理·nginx是什么·nginx静态资源服务器·nginx服务器·nginx解决哪些问题
Michaelwubo3 小时前
Docker dockerfile镜像编码 centos7
运维·docker·容器
远游客07133 小时前
centos stream 8下载安装遇到的坑
linux·服务器·centos
马甲是掉不了一点的<.<3 小时前
本地电脑使用命令行上传文件至远程服务器
linux·scp·cmd·远程文件上传
jingyu飞鸟3 小时前
centos-stream9系统安装docker
linux·docker·centos
好像是个likun4 小时前
使用docker拉取镜像很慢或者总是超时的问题
运维·docker·容器
超爱吃士力架4 小时前
邀请逻辑
java·linux·后端