so 动态库文件和静态库文件区别
在Linux操作系统中,普遍使用ELF格式作为可执行程序或者程序生成过程中的中间格式。ELF(Executable and Linking Format,可执行连接格式)。
ELF文件分类
ELF文件格式包括三种主要的类型:可执行文件、可重定向文件、共享库:
1、可执行文件(应用程序)
可执行文件包含了代码和数据,是可以直接运行的程序。
2、可重定向文件(.o)
可重定向文件又称为目标文件,它包含了代码和数据(这些数据是和其他重定位文件和共享的object文件一起连接时使用的)。
.o文件参与程序的连接(创建一个程序)和程序的执行(运行一个程序),它提供了一个方便有效的方法来用并行的视角看待文件的内容,这些*.o文件的活动可以反映出不同的需要。
Linux下,我们可以用gcc -c编译源文件时可将其编译成*.o格式。
3、共享文件(*.so)
也称为动态库文件,它包含了代码和数据(这些数据是在连接时候被连接器ld和运行时动态连接器使用的)。动态连接器可能称为ld.so.1,libc.so.1或者 ld-linux.so.1。
动态链接库和静态链接库的区别
动态链接库就像是python 中的库一样,但是事程序实时调用的二进制文件,静态链接库就像是一个不可移动的库文件,很多的数据都能在其中找到,因此叫做静态数据库。
静态库
生成xxx.o文件
gcc -c xxx.c
将.o文件转化成.a ,利用ar命令,生成xxx.a的静态文件
ar crs xxx.a xxx.o
生成了静态的库文件,同时可以将多个二进制的文件进行组装到一个静态库中。
同时可以使用ar -t 来查看静态库中拥有哪些obj文件
然后我们可以使用
gcc -o xxx xxx.c -L, -xxx
-L 表示当前文件夹下面,xxx代表了刚才生成的静态库文件名称。
动态库
动态库是程序运行时加载的库,只有在动态链接正确安装之后,所有的程序就可以使用动态库来运行程序,动态库是目标文件的集和,目标文件在动态链接库中的组织方式是按照特殊方式形成的。库中函数和变量的地址是相对的,每次调用都有可能产生新的地址,可以利用puts等函数来读出地址,进行漏洞调用。
利用.o文件创建动态链接库:
fs@ubuntu:~/qiang/lib/dylib$ gcc -fPIC -Wall -c dy1.c dy2.c
fs@ubuntu:~/qiang/lib/dylib$ gcc -shared -o libtest.so dy1.o dy2.o
fs@ubuntu:~/qiang/lib/dylib$
这里的 -fPIC 指创建与地址无关的编译程序, -share 生成动态链接库。
下面我们就能够使用动态链接:
fs@ubuntu:~/qiang/lib/dylib$ gcc -o test main.c -L. -ltest
fs@ubuntu:~/qiang/lib/dylib$ ls
dy1.c dy2.c libtest.so main.c mylib.h test
这里的l 是动态库的调用规则,因为linux系统的动态库命名方式是lib*.so 所以这里*代表了自己的库名。
直到这里我们依然无法利用动态链接库来进行程序运行,因为程序没有找到动态链接库,这里有三种解决方法,
1.将动态链接库放到 /usr/lib/以及/lib目录下
cp libtest.so /lib
详细链接