Linux:库

目录

静态库

动态库

目标文件

ELF文件 

ELF形成可执行

ELF可执行加载

 ELF加载

全局偏移量表GOT(global offset table) 


库是写好的,成熟的,可以复用的代码

现实中每个程序都要依赖很多的基础的底层库,不可能都是从零开始的

库有两种:

  • 静态库 .a[Linux]、.lib[windows]
  • 动态库 .so[Linux]、.dll[windows]

静态库

程序在编译链接的时候把库的代码链接到可执行文件中,程序运行的时候将不再需要静态库

一个可执行程序可能用到多个库,这些库可能有的是静态库,有的是动态库,而我们编译默认链接为动态库,只有在该库下找不到动态.so的时候才会采用同名静态库。

若是想使用静态库我们可以使用gcc的 -static 强转设置链接静态库

 静态库的生成:

ar -rc libmylib.a mylib.o

 若我们有一个自己写的库叫mylib,那么我们该如何使用它呢?


若头文件和库文件都被我们安装到系统的路径下

/usr/lib、/usr/lib64、/usr/local/lib等等

gcc main.c -lmystdio

 头文件和库文件和我们自己的源文件在同一个路径下

gcc main.c -L. -lmylib

头文件和库文件都有自己独立的路径

gcc main.c -I头⽂件路径 -L库⽂件路径 -lmylib
  •  -L:指定库路径
  • -I:指定头文件搜索路径
  • -l:指定库名

动态库

程序在运行的时候才去链接动态库,多个程序可以共享使用库的代码

一个与动态库链接的可执行程序仅仅包含它用到的函数入口地址的一个表,而不是外部函数所在目标文件的整个机器码

在可执行文件开始运行以前,外部函数的机器码由操作系统从磁盘上的该动态库中复制到内存中,这个过程称为动态链接

动态库可以在多个程序间共享,所以动态链接使得可执行文件更小,节省了磁盘的空间。操作系统采用虚拟内存机制允许物理内存中的一份动态库被要用到该库的所有进程共用,节省了内存和磁盘空间

动态库的生成:

gcc -fPIC -c main.c -o mylib.o

你可能感兴趣的:(linux,运维,服务器)