Linux下的动态库和静态库

   我们通常把一些公用函数制作成函数库,供其它程序使用。函数库分为静态库动态库两种。

区别:1、静态库在程序编译时被连接到目标代码中,程序运行时将不再需要该静态库。

           2、动态库在程序编译时并不会被连接到目标代码中,而是在程序运行时才被载入,因此在程序运行时还需要动态库存在。

本文主要通过举例来说明在Linux中如何创建静态库和动态库,以及使用它们。 

    在创建函数库前,我们先来准备举例用的源程序,并将函数库的源程序编译成.o文件。 

第1步:编辑得到举例的程序--hello.h、hello.c和main.c;

//hello.h
#ifndef HELLO_H
#define HELLO_H

void hello(const char *name);

#endif //HELLO_H
//hello.c
#include "hello.h"
void hello(const char *name)
{
	printf("Hello %s!\n", name);
}
//main.c
#include "hello.h"

int main()
{

hello("everyone");

return 0;

}

第2步:将hello.c编译成.o文件;

注意:无论静态库,还是动态库,都是由.o文件创建的。因此,我们必须将源程序hello.c通过gcc先编译成.o文件

在系统提示符下键入以下命令得到hello.o文件。
# gcc -c hello.c

第3步:由.o文件创建动态库文件;

    动态库文件名命名规范和静态库文件名命名规范类似,也是在动态库名增加前缀lib,但其文件扩展名为.so。例如:我们将创建的动态库名为myhello,则动态库文件名就是libmyhello.so。用gcc来创建动态库。    

在系统提示符下键入以下命令得到动态库文件libmyhello.so。

# gcc -shared -fPIC -o libmyhello.so hello.o 

第4步:在程序中使用动态库; 

在程序中使用动态库和使用静态库完全一样,也是在使用到这些公用函数的源程序中包含这些公用函数的原型声明,然后在用gcc命令生成目标文件时指明动态库名进行编译。我们先运行gcc命令生成目标文件,再运行它看看结果。

# gcc -o hello main.c -L. -lmyhello

# ./hello

./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory

#

哦!出错了。快看看错误提示,原来是找不到动态库文件libmyhello.so。程序在运行时,会在/usr/lib和/lib等目录中查找需要的动态库文件。若找到,则载入动态库,否则将提示类似上述错误而终止程序运行。我们将文件 libmyhello.so复制到目录/usr/lib中,再试试。

# mv libmyhello.so /usr/lib

# ./hello

Hello everyone!

#

成功了。这也进一步说明了动态库在程序运行时是需要的。 

转载:https://wenda.so.com/q/1458238619723804

猜你喜欢

转载自blog.csdn.net/qq_39736982/article/details/81536264