linux 动、静态库生成与使用

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。



库是一种软件组件技术,库里面封装了数据和函数。

库的使用可以使程序模块化。
Windows系统包括静态链接库(.lib文件)和动态链接库(.dll文件)。
Linux通常把库文件存放在/usr/lib或/lib目录下。
Linux库文件名由:前缀lib、库名和后缀3部分组成,其中动态链接库以.so最为后缀,静态链接库通常以.a作为后缀。
在程序中使用使用静态库和动态库时,他们载入的顺序是不同的。
静态库的代码在编译时就拷贝的应用程序中,这样的优点是节省编译时间。
动态链接库时程序在开始运行后调用库函数时才被载入。

静态库的创建和使用:
1、在一个头文件种声明静态库所导出的函数。
2、在一个源文件种实现静态库所导出的函数。
3、编译源文件,生成可执行代码。
4、将可执行代码所在的目标文件加入到某个静态库中,并将静态库拷贝到系统默认的存放库文件的目录下。
下面通过一个例子来说明:mylib.h种存放的是静态库提供给用户使用的函数的声明,mylib.c实现了mylib.h种声明的函数。

头文件:mylib.h
#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

2>将目标文件加入到静态库中:ar rcs libmylib.a mylib.o
3>将静态库copy到Linux的库目录(/usr/lib或者/lib)下:
cp libmylib.a /usr/lib/libmylib.a 
编写调用库函数的测试程序test.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

这里注意,编译时无需带上前缀和后缀。
5>运行可执行程序test: ./test
create and use library:
welcome to libmylib
it's successful

在Linxu下,可以使用ar命令来创建和修改静态库。

这些在linux下man ar一下就可以得到参数,这里说明几个常用的
d:从库中删除成员文件。
r:在库中加入成员文件,若存在,则替换。
c:创建一个库。
s:无论ar命令是否修改了库内容,都强制重新生成库符号表。
其他的命令用时再man。

上面这五步是基本的使用,还有需要的话,就要深入的学习了。


你可能感兴趣的:(linux 动、静态库生成与使用)