Linux下动态库文件的扩展名为".so"(Shared Object)。按照约定,所有动态库文件名的形式是libname.so(可能在名字中加入版本号)。静态库的文件名形式是libname.a。
本文仅以简单的例子介绍动态库文件的生成和链接方法。
一、库文件及测试文件代码
库文件及测试文件所在的目录:/root/so/
1.库文件名:myfirstso.c
#include <stdio.h>
void myfunction()
{
printf("this is a shared object\n");
}
2.测试文件名:test.c
#include <stdio.h>
int main(int argc,char *argv[])
{
myfunction();
return 0;
}
二、动态库的编译方法
编译库文件myfirstso.c:
[root@mgt so]# gcc -fPIC -shared -o libmyfirstso.so myfirstso.c
如果编译成功,会在 /root/so/下生成动态库文件:libmyfunction.so。
编译生成动态库的命令为:gcc (-fpic) -shared -o libmyfunction.so myfunction.c
-fpic 使输出的对象模块是按照可重定位地址方式生成的。
-shared指定把对应的源文件生成对应的动态链接库文件。
三、动态库的测试方法
编译测试文件test.c:
[root@mgt so]# gcc -o test test.c /root/so/libmyfirstso.so
成功编译后,生成test文件,运行test:
[root@mgt so]# ./test
this is a shared object
其中,gcc -o test test.c /root/so/libmyfirstso.so的最后一个参数指定所链接库文件的绝对路径。本例中库文件的绝对路径为:/root/so/libmyfirstso.so。如果直接写相对路径会有错误。
当然,如果想从系统的库文件路径(通常系统函数库的位于/usr/lib下)链接动态库的话,可以先将生成的库文件拷贝至/usr/lib/下,然后再链接:
[root@mgt so]# cp libmyfirstso.so /usr/lib
[root@mgt so]# gcc -o test test.c -lmyfirstso
[root@mgt so]# ./test
this is a shared object
这里,对于链接的方法作一下解释。对于gcc -o test test.c -lmyfunction中最后一个参数- lmyfirstso, 可见传给C编译器的命令行参数并未提到函数库的完整路径名,甚至没有提到在函数库目录中该文件的完整名字!实际上,编译器被告知根据选项- lmyfirstso链接到相应的函数库(/usr/lib下,注意如果是64的系统应该是/usr/lib64),函数库的名字是libmyfirstso.so, 也就是说,"lib"部分和文件的扩展名被省略了,但在前面加了一个l。
库是一种软件组件技术,库里面封装了数据和函数。
#ifndef _MYLIB_H_ #define _MYLIB_H_ void weclome(void); void outString(const char *str); #endif
源文件:mylib.c
#include "mylib.h" #include void welcome(void) { printf("welcome to libmylib\n"); } void outString(const char *str) { if(str != NULL) printf("%s\n", str); }
1>编译mylib.c生成目标文件:gcc -o mylib.o -c mylib.c
#include "mylib.h" #include int main(void) { printf("create and use library:\n"); welcome(); outString("it's successful\n"); return 0; }
4>使用静态库编译:gcc -o test test.c -lmylib
create and use library: welcome to libmylib it's successful
在Linxu下,可以使用ar命令来创建和修改静态库。