Linux系统下动态库的生成方式
本篇内容介绍了“Linux系统下动态库的生成方式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
什么是动态库?
动态库又称动态链接库英文为DLL,是Dynamic Link Library 的缩写形式,DLL是一个包含可由多个程序同时使用的代码和数据的库,DLL不是可执行文件。动态链接提供了一种方法,使进程可以调用不属于其可执行代码的函数。函数的可执行代码位于一个 DLL 中,该 DLL 包含一个或多个已被编译、链接并与使用它们的进程分开存储的函数。DLL 还有助于共享数据和资源。多个应用程序可同时访问内存中单个DLL 副本的内容。DLL 是一个包含可由多个程序同时使用的代码和数据的库。
一、简述
Linux下动态库文件的扩展名为 ".so"(Shared Object)。按照约定,所有动态库文件名的形式是libname.so(可能在名字中加入版本号)。这样,线程函数库被称作libthread.so。静态库的文件名形式是libname.a。共享archive的文件名形式是libname.sa。共享archive只是一种过渡形式,帮助人们从静态库转变到动态库。
小编综合自己学习体会以及网络上较好的内容,以简单的例子介绍动态库文件的生成和链接方法。
操作系统:Ubuntu 14.0.4
GCC版本:4.1.3
二、库文件及测试文件代码
库文件及测试文件所在的目录:/home/test/program/
1、 库文件名:myLibclass="lazy" data-src.c
代码如下:
#include<stdio.h>
#include"myLibInclude.h"
int
myLibclass="lazy" data-srcFun(){
printf("There is myLibclass="lazy" data-srcFun()\n");
return 0;
}
2、 测试文件:main.c
代码如下:
#include<stdio.h>
#include"myLibInclude.h"
int main(intargc, char** argv){
printf("Main function !\n");
//调用加载的动态库里的函数
myLibclass="lazy" data-srcFun();
return 0;
}
<strong>3、 头文件:myLibInclude.h</strong>
intmyLibclass="lazy" data-srcFun();//声明一下函数
三、动态库的编译方法
编译库文件 myLibclass="lazy" data-src.c 命令如下:
代码如下:
$ gcc myLibclass="lazy" data-src.c -shared -o libmyLib.so
或是:$ gcc myLibclass="lazy" data-src.c -fpic-shared -g -DDEBUG -o libmyLib.so
如果编译成功,会在目录/home/test/program/ 下生成动态库文件:libmyLib.so
这里有两点需要补充说明:
A、 对于Linux操作,一般都推荐在普通用户模式下,如果需要超级用户的权限,则可以通过sudo 或是 su root ,输入root用户密码切换。鉴于个人学习使用时,同时很多操作又需都需要使用root用户,因此 就直接在root用户下进行编译。
B、 编译生成动态库时的参数含义
-fpic: 使输出的对象模块可重定位地址方式生成的。
-shared: 指定把对应的源文件生成对应的动态链接库文件。
四、动态库的测试方法
编译测试文件:main.c
代码如下:
$gcc–o app main.c /home/test/program/ libmyLib.so
编译成功后运行 ./app :
代码如下:
Main function !
There is myLibclass="lazy" data-srcFun()
需要注意的是:
1、上面编译的命令 $gcc –o app main.c /home/test/program/ libmyLib.so
的最后一个参数是指定特定所连接库文件的绝对路径。本例中的库文件的绝对路径即为/home/test/program/ libmyLib.so
当然,如果想从系统的库文件路径(通常系统函数库都位于 /usr/lib 目录下)链接动态库的话,可以先将生成的 库文件 拷贝至 /usr/lib下,然后在链接:
代码如下:
$cp libmyLib.so /usr/lib/libmyLib.so
$gcc –o app main.c -lmyLib
这里,对于链接的方法做一下简单的解释:对于$ gcc –o app main.c -lmyLib 中的最后一个参数 –lmyLib ,可见传递给C的编译器的命令行参数并未提到函数库的完整路径,甚至没有提到在函数库目录 中该文件的完整名字!实际上,编译器被告知根据选项 -lmyLib 链接到相应的函数库(/usr/lib 下),函数库的名字是 libmyLib.so,也就是说,“lib”部分和文件的扩展名都被省略了,但在前面加了一个 ‘l’.
“Linux系统下动态库的生成方式”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341