初识Linux · 动静态库(incomplete)

前言:

在前文中,我们从磁盘的理解,逐步构建了文件系统框架,并探讨了软硬链接,逐渐理解了为什么运行程序需要使用./a.out,以及前面的点号的含义。

在文件权限部分,我们接触了最基本的库,了解到linux系统中动态库的后缀是.so,静态库是.a,而windows系统中动态库是.dll,静态库是.lib。我们也知道库的名字需要去掉前缀和后缀,这是我们对库的初步认识。

那么,我们是否已经使用过库呢?

当然是使用过的。在使用c语言c++时,我们用到的头文件就位于库中,比如标准库(std库),我们肯定是用过的。那么,库的作用是什么呢?

在STL容器中,都有基本函数的接口,比如vector的push_back,我们使用的是这些接口,那么具体的实现又在哪里呢?

具体的实现肯定是放在.cc文件中,通过编译器编译成.o文件,然后这些文件被合并,形成了最终的库。

现在,我们就从“是什么”、“为什么”和“怎么办”三个方面来讨论静态库和动态库。

静态库为了生成静态库,我们首先模拟实现多个.c文件和多个.h文件:

初识Linux · 动静态库(incomplete)

然后在这些文件中写入对应的代码:

#pragma once int Sub(int x, int y); <h1>include "sub.h"</h1><p>int Sub(int x, int y) { return x - y; }</p><h1>include "add.h"</h1><p>int Add(int x, int y) { return x + y; }</p><h1>pragma once</h1><p>int Add(int x, int y);

我们创建了两个.c文件和两个.h文件。

然后我们在test.c文件中进行测试:

#include <stdio.h></p><h1>include "add.h"</h1><h1>include "sub.h"</h1><p>int main() { printf("a + b = %dn", Add(10,20)); printf("a - b = %dn", Sub(10,20)); return 0; }

如果我们直接编译,肯定是无法通过的,因为真正的实现是在.c文件中:

初识Linux · 动静态库(incomplete)

那么我们不妨先生成.o文件,为静态库做准备:

初识Linux · 动静态库(incomplete)

然后使用ar命令生成静态库:

初识Linux · 动静态库(incomplete)

其中,replace是r,c是create,如果库不存在则创建。

初识Linux · 动静态库(incomplete)

这是静态库的创建过程,libmyc.a就是我们创建的静态库,但实际上,myc才是这个静态库的名称。

然而,对于库的使用来说,比如C语言提供多个库,我们都是通过#include 来使用的,编译器会在安装好的库中查找,因此这里肯定存在路径问题。

初识Linux · 动静态库(incomplete)

使用-L和-l选项可以解决这个问题。

动态库的部分将在后续文章中介绍。

这里还涉及一些附加问题,将在后续更新中详细讨论。

感谢阅读!

© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享