其他分享
首页 > 其他分享> > GCC静态库、动态库探幽

GCC静态库、动态库探幽

作者:互联网

一、:编辑生成例子程序 hello.h、hello.c 和 main.c

首先编辑hello.h文件内容

  

 

 

  hello.c

 

  

 

 

   main.c
  

 

 

   样例的三个代码如下:

  

程序 1: hello.h
ifndef HELLO_H
define HELLO_H
void hello(const char *name);
endif //HELLO_H

程序 2: hello.c
#include <stdio.h>
void hello(const char *name)
{
printf("Hello %s!\n", name);
}

程序 3: main.c
#include "hello.h"
int main()
{
hello("everyone");
return 0;
}

如上 我们就完成了第一步工作。

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

无论静态库,还是动态库,都是由.o 文件创建的。因此,我们必须将源程序 hello.c 通过 g cc 先编译成.o 文件。在系统提示符下键入以下命令得到 hello.o 文件。

  

 

 

   在 ls 命令结果中,我们看到了 hello.o 文件,本步操作完成。 下面我们先来看看如何创建静态库,以及使用它。

三、:由.o 文件创建静态库
静态库文件名的命名规范是以 lib 为前缀,紧接着跟静态库名,扩展名为.a。例如:我们将 创建的静态库名为 myhello,则静态库文件名就是 libmyhello.a。在创建和使用静态库时, 需要注意这点。创建静态库用 ar 命令。在系统提示符下键入以下命令将创建静态库文件 libmyhello.a。

 

四、:静态库在程序中使用

提供了三种可以参考的方法,文章中实际操作才用了第二种

静态库制作完了,如何使用它内部的函数呢?只需要在使用到这些公用函数的源程序中包
含这些公用函数的原型声明,然后在用 gcc 命令生成目标文件时指明静态库名,gcc 将会从
静态库中将公用函数连接到目标文件中。注意,gcc 会在静态库名前加上前缀 lib,然后追
加扩展名.a 得到的静态库文件名来查找静态库文件。
在程序 3:main.c 中,我们包含了静态库的头文件 hello.h,然后在主程序 main 中直接调用
公用函数 hello。下面先生成目标程序 hello,然后运行 hello 程序看看结果如何。

方法一: # gcc -o hello main.c -L. –lmyhello 自定义的库时,main.c 还可放在-L.和 –lmyhello 之间,但是不能放在它俩之后,否则会提 示 myhello 没定义,但是是系统的库时,如 g++ -o main(-L/usr/lib) -lpthread main.cpp 就不出错。
方法二: #gcc main.c libmyhello.a -o hello
方法三: 先生成 main.o: gcc -c main.c 再生成可执行文件: gcc -o hello main.o libmyhello.a 动态库连接时也可以这样做。 # ./hello Hello everyone!

 

 

 

 

我们删除静态库文件试试公用函数 hello 是否真的连接到目标文件 hello 中了。 # rm libmyhello.a rm: remove regular file `libmyhello.a'? y # ./hello Hello everyone! # 程序照常运行,静态库中的公用函数已经连接到目标文件中了。 我们继续看看如何在 Linux 中创建动态库。我们还是从.o 文件开始。

 

 

 程序照常运行,静态库中的公用函数已经连接到目标文件中了。

接下来我们继续看看如何在 Linux 中创建动态库。我们还是从.o 文件开始

 

五、由.o 文件创建动态库文件

动态库文件名命名规范和静态库文件名命名规范类似,也是在动态库名增加前缀 lib,但其 文件扩展名为.so。例如:我们将创建的动态库名为 myhello,则动态库文件名就是 libmyh ello.so。用 gcc 来创建动态库。 在系统提示符下键入以下命令得到动态库文件 libmyhello.so。

 

 输入以下命令 生成.so文件 同时利用ls查看是否生成

六、在程序中使用动态库

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

 warning:#gcc main.c libmyhello.so -o hello 不会出错(没有 libmyhello.so 的话,会出错),但是 接下来./hello 会提示出错,因为虽然连接时用的是当前目录的动态库,但是运行时,是到 /usr/lib 中找库文件的,将文件 libmyhello.so 复制到目录/usr/lib 中

  

 

 

 

   

 

 成功运行!

最后:一探究竟

上述步骤进一步说明了动态库在程序运行时是需要的。 我们回过头看看,发现使用静态库和使用动态库编译成目标程序使用的 gcc 命令完全一样, 那当静态库和动态库同名时,gcc 命令会使用哪个库文件呢?抱着对问题必究到底的心情, 来试试看。 先删除除.c 和.h 外的所有文件,恢复成我们刚刚编辑完举例程序状态。

 

 再来创建静态库文件 libmyhello.a 和动态库文件 libmyhello.so

 通过上述最后一条 ls 命令,可以发现静态库文件 libmyhello.a 和动态库文件 libmyhello.s o 都已经生成,并都在当前目录中。然后,我们运行 gcc 命令来使用函数库 myhello 生成目 标文件 hello,并运行程序 hello。

# gcc -o hello main.c -L. –lmyhello
(动态库和静态库同时存在时,优先使用动态库,当然,如果直接
#gcc main.c libmyhello.a -o hello 的话,就是指定为静态库了)
# ./hello
./hello: error while loading shared libraries: libmyhello.so: cannot open shar
ed object file: No such file or directory
#
从程序 hello 运行的结果中很容易知道,当静态库和动态库同名时,gcc 命令将优先使用动
态库,默认去连/usr/lib 和/lib 等目录中的动态库,将文件 libmyhello.so 复制到目录/usr/lib
中即可。

 实验心得:本次实验更加深入的了解和体会了GCC的使用过程,已经了解巩固了Linux的一些文件的命令,在实验过程中虽然曲折,遇到了一些问题,但是通过文档和Google的方式得以解决,在其中体会到了许多乐趣,以及更加进一步的了解动态库和静态库的不同区别,感觉对于GCC的了解加深了一些,同时更加喜欢了Linux下的操作方式,很有收获

 

标签:文件,GCC,libmyhello,静态,gcc,探幽,main,hello
来源: https://www.cnblogs.com/LinZJ0423/p/15371756.html