news 2026/4/23 11:25:17

【Linux】库制作与原理(二):动态库的制作与使用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Linux】库制作与原理(二):动态库的制作与使用

✨道路是曲折的,前途是光明的!

📝 专注C/C++、Linux编程与人工智能领域,分享学习笔记!

🌟 感谢各位小伙伴的长期陪伴与支持,欢迎文末添加好友一起交流!

  • 一、基础背景
  • 二、动态库的制作
  • 三、动态库的使用
  • 四、总结

一、基础背景

一些动静态库的基础知识和静态库的制作与使用的讲解请点击:【Linux】库制作与原理(一):静态库的制作与使用


二、动态库的制作

  1. 我们静态库实现的是一个加法的使用,我们动态库的演示就来一个减法和乘法吧,我们需要用要的两个源文件sub.cmul.c,两个头文件sub.hmul.h
#pragmaonceexternintmy_sub(intx,inty);#include"sub.h"intmy_sub(intx,inty){returnx-y;}#pragmaonceexternintmy_mul(intx,inty);#include"mul.h"intmy_mul(intx,inty){returnx*y;}

  1. 其制作与静态库有些类似,但是所用的选项和打包工具是不同的,我们先看Makefile自动化构建里面的代码,再来介绍一下不同之处。
lib = libmymath.so $(lib):sub.o mul.o gcc -shared -o $@ $^ sub.o:sub.c gcc -fPIC -c $^ -o $@ mul.o:mul.c gcc -fPIC -c $^ -o $@ .PHONY:clean clean: rm -rf *.o *.so mylib .PHONY:output output:$(lib) mkdir -p mylib/include mkdir -p mylib/mathlib cp *.h mylib/include cp *.so mylib/mathlib

具体的注释请看上一篇文章静态库的制作与使用,这里我们只看不同点。

  • 我们这里看到gcc指令多了一个-fPIC,这个是用来产生位置无关码
  • 形成动态库的时候-shared这个是专门用来形成.so后最的动态库文件指令
  1. 执行我们自动化构建工具的指令

  • 我们先通过ls看一下权限.

  • 其实是因为动态库(如 libmymethod.so)的可执行权限(x)并非指其能被直接运行,而是因为可执行程序本身具备可执行权限,在运行时会跳转调用动态库中的函数逻辑,因此动态库的 x 权限本质是为了支撑可执行程序对其函数的调用执行,是一种 “间接的可执行能力”

注意:静态库无需加载,且无可执行权限(x):因为静态库在链接阶段会将所需函数代码直接拷贝到可执行程序中,拷贝完成后静态库即完成使命,其代码成为可执行程序的一部分;最终运行时,可执行程序直接在自身内存空间执行这些代码,无需跳转至静态库,因此静态库既无需加载,也不需要可执行权限(x),可执行程序也不再依赖静态库。


三、动态库的使用

  1. 我们此时站在用户的角度使用我们制作的动态库,首先要准备好自己的测试文件test.c(下面再写),然后把我们提供的动态库目录(mylib)移动到测试目录下(以此模拟用户下载并存放库文件的操作)。

#include<stdio.h>#include"sub.h"#include"mul.h"intmain(){inta=20;intb=10;intc=my_sub(a,b);intd=my_mul(a,b);printf("a - b = %d\n",c);printf("a * b = %d\n",d);return0;}
  1. 和静态库一样我们这里gcc时候直接带上-I,-L,-l指令

  • 我们发现并没有静态库的使用那么简单,当有了可执行程序文件我们执行的时候还是失败了,它找不到我们的共享库,即使这里我们告知了动态库所在的路径以及哪一个动态库,这是为什么?
  • 因为编译时指定路径 ≠ 运行时能找到库,这也是动态库比静态库复杂的根本原因。编译链接阶段运行加载阶段完全独立的两个过程,
  • 编译器的工作只到 “生成可执行程序(a.out/test)” 为止,它不会把 “动态库的路径” 写入可执行程序中。
  • 那么该如何解决这种问题?

  1. 法一:把动态库拷贝到系统目录下
  • sudo libmymath.so /usr/local/lib
  • sudo ldconfig

  • 此时我们我们在运行./a.out

  • 我们先删除一下上面拷贝到系统下的库,然后同样的刷新缓存一下,发现又找不到了,说明删除成功
  • sudo rm /usr/local/lib/libmymath.so


  1. 法二:在系统默认路径下建立软链接,这里建议使用绝对路径,避免成为无效链接。
  • sudo ln -s /home/dh/study/2-4/libmymath.so /usr/local/lib/libmymath

  • sudo unlink /usr/local/lib/libmymath.so直接删除我们的软链接


  1. 法三:更改LD_LIBRARY_PATH,也就是把自己库所在的路径添加到环境变量里边
  • export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:XXXXX

  • 这个export命令是临时生效的 —— 关闭当前终端、重启电脑,或新开终端后,LD_LIBRARY_PATH会变回空。

  1. 法四:配置/etc/ld.so.conf.d,在这个路径下新建自己的动态库路径配置文件,然后刷新缓存

删除的话,只要我们缺到在上面的路径下,直接执行rm即可


四、总结

  • 本文详细介绍了Linux下动态库(以libmymath.so为例)的制作与使用:制作时需准备功能源文件(sub.c/mul.c)和头文件(sub.h/mul.h),通过gcc -fPIC生成位置无关码、-shared打包为动态库,并用Makefile自动化构建整理文件。
  • 使用时需用-I/-L/-l指定头文件和库路径,但动态库编译时指定路径不等于运行时能找到,核心原因是编译与运行阶段相互独立。
  • 需通过“拷贝库到系统目录+刷新缓存”“建立软链接”“设置LD_LIBRARY_PATH环境变量”“配置/etc/ld.so.conf.d目录”四种方法解决。
  • 相比静态库,动态库需依赖外部文件、有间接可执行权限、可共享节省空间且更新方便,而静态库链接后无依赖、无x权限,两者各有优劣,实操中需根据需求选择合适方式。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/19 14:32:34

【开题答辩全过程】以 基于SpringBoot的动物领养平台为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华
网站建设 2026/4/23 8:52:52

AI写论文有妙招!这4款AI论文写作工具,让毕业论文轻松过关!

在撰写期刊论文、毕业论文本或职称论文的过程中&#xff0c;学术人员常常会遭遇各种困难。人工撰写论文时&#xff0c;面对大量的文献和资料&#xff0c;查找相关信息有时候就像在汪洋大海中寻找一根针&#xff1b;而对于复杂而严格的格式要求&#xff0c;许多人也是感到无比头…

作者头像 李华
网站建设 2026/4/17 18:00:39

计算机毕业设计springboot书海拾梦 墨香书苑 —— 基于SpringBoot的在线图书阅读与推荐平台 阅界云书 —— 智能图书推荐与文学交流社区

计算机毕业设计springboot书海拾梦59p3tjd9 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。在数字化浪潮席卷全球的当下&#xff0c;传统阅读方式正经历深刻变革。移动互联网的普…

作者头像 李华
网站建设 2026/4/23 9:46:26

汽车行业BOM管理如何集成UEDITOR的EXCEL导入功能?

农业集团信息管理系统富文本增强功能开发全记录 一、需求分析与技术选型 作为湖南某农业集团技术负责人&#xff0c;近期接到客户核心需求&#xff1a;在现有信息管理系统的后台文章发布模块中新增两大功能&#xff1a; 智能粘贴功能&#xff1a;支持从Word/微信公众号直接粘…

作者头像 李华
网站建设 2026/4/23 9:45:06

蓝易云 :【redis问题】Caused by: io.netty.channel

下面这份说明&#xff0c;专门针对 Redis 场景中常见的 Caused by: io.netty.channel 异常&#xff0c;从 底层原理 → 真实成因 → 精准处理方案 全链路拆解&#xff0c;不猜、不虚、不糊弄&#xff0c;全部基于真实生产经验。 一、先说结论&#xff1a;这不是 Redis 本身的错…

作者头像 李华