动态库与静态库的异同、生成和使用详解
下面表格实例中,实现了把test模块分别生成动态库(libtest.so)和静态库(libtest.a),并使用了生成的库。详情和注解如下:
类型 | 生成 | 使用 | 异同 | 其他 |
动态库(.so格式) |
1.先编译成.o文件: gcc -c test.c -o test.o; 2.封装成动态库: gcc -share -fPCI -o libtest.so test.o |
法一: gcc -o test main.c -L. -ltest;(见注解A); |
1.动态函数库在编译的时候并没有被编译进目标代码中, 你的程序执行到相关函数时才调用该函数库里的相应函数, 因此动态函数库所产生的可执行文件比较小。 由于函数库没有被整合进你的程序,而是程序运行时动态的 申请并调用,所以程序的运行环境中必须提供相应的库。 2.动态库内可嵌套使用多层的静态和动态库; 动态函数库的改变并不影响你的程序,所以动态函数库的升级比较方便。 |
|
静态库(.a格式) |
1.同上; 2.封装成静态库: ar crv libtest.a test.o; |
法一:同上; 法二: gcc main.c libtest.a -o test |
1.利用静态函数库编译成的文件比较大,因为整个 函数库的 所有数据都会被整合进目标代码中,他的优点就显而易见了, 即编译后的执行程序不需要外部的函数库支持,因为所有使 用的函数都已经被编译进去了。当然这也会成为他的缺点, 2.静态库内不能嵌套使用静态或动态库 如果静态函数库改变了,那么你的程序必须重新编译。 |
注解:
test.c -----测试功能模块的c文件
test.h -----测试功能模块的头文件
main.c -----include“test.h”的主函数文件
-share -----该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成弱连接W类型的导出符号),不用该标志外部程序无法连接。
相当于一个可执行文件。
-fPCI -----表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通过代码拷贝的方式来满足不同进程的需要,而不
能达到真正代码段共 享的目的。
注解A:在使用到这些公用函数的源程序中包含这些公用函数的原型声明,然后在用 gcc 命令生成目标文件时指明静态库名,gcc 将会从静态库中
将公用函数连接到目标文件中。注意,gcc 会在静态库名前加上前缀 lib,然后追加扩展名.a 得到的静态库文件名来查找静态库文
件。