前言:
在前文中,我们从磁盘的理解,逐步构建了文件系统框架,并探讨了软硬链接,逐渐理解了为什么运行程序需要使用./a.out,以及前面的点号的含义。
在文件权限部分,我们接触了最基本的库,了解到linux系统中动态库的后缀是.so,静态库是.a,而windows系统中动态库是.dll,静态库是.lib。我们也知道库的名字需要去掉前缀和后缀,这是我们对库的初步认识。
那么,我们是否已经使用过库呢?
当然是使用过的。在使用c语言和c++时,我们用到的头文件就位于库中,比如标准库(std库),我们肯定是用过的。那么,库的作用是什么呢?
在STL容器中,都有基本函数的接口,比如vector的push_back,我们使用的是这些接口,那么具体的实现又在哪里呢?
具体的实现肯定是放在.cc文件中,通过编译器编译成.o文件,然后这些文件被合并,形成了最终的库。
现在,我们就从“是什么”、“为什么”和“怎么办”三个方面来讨论静态库和动态库。
静态库为了生成静态库,我们首先模拟实现多个.c文件和多个.h文件:
然后在这些文件中写入对应的代码:
#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文件中:
那么我们不妨先生成.o文件,为静态库做准备:
然后使用ar命令生成静态库:
其中,replace是r,c是create,如果库不存在则创建。
这是静态库的创建过程,libmyc.a就是我们创建的静态库,但实际上,myc才是这个静态库的名称。
然而,对于库的使用来说,比如C语言提供多个库,我们都是通过#include
使用-L和-l选项可以解决这个问题。
动态库的部分将在后续文章中介绍。
这里还涉及一些附加问题,将在后续更新中详细讨论。
感谢阅读!