Linux系统中静态库和动态库的生成和使用

分类: 系统管理   出处:iocblog整理  更新时间:2009-02-08   添加到收藏  

       一、静态库的创建和使用:

 

1、生成静态库 :库名 libmylib.a

ar rcs libmylib.a mylib.o

2、将静态库copy到 /usr/lib/ 或/lib/ 目录下

cp libmylib.a /usr/lib/

3、静态库的使用

比如测试文件为test.c

gcc -0 test test.c -lmylib

-l为选项, mylib为库名。mylib为libmylib的中间部分,linux下约定所有库都以前缀lib开始

静态库以.a结尾,动态库以.so结尾。再编译程式时,无需带上前缀和后缀。

注意:静态库的命名需要以"lib"开头,否者连接是编译器无法找到库

 

二、动态库的创建和使用:

 

1、下面命令把mylib.c程序创建成了一个动态库

(1)、gcc -fpic -o mylib.o -c mylib.c

(2)、gcc -shared -o libttt.so mylib.o

也可以直接使用一条命令

gcc -fpic -shared -o libttt.so mylib.c

 

2、linux有两种方式调用动态库连接中的函数

(1)、gcc -o test test.c ./libttt.so

(2)、cp libttt.so /usr/lib/libttt.so

gcc -o test test.c /usr/lib/libttt.so

注意:引用动态库时,必须含有路径,如果只是使用libttt.so,则必须确保这个库所在目录包括再path 环境变量中

 

三、系统函数使用动态库:

 

1、void *dlopen(const char *filename, int flag)

用于打开指定名字的动态链接库,并返回一个句柄

flag:rtld_lazy, rtld_new, rtld_global

rtld_lazy:在dlopen()返回前,对于动态库中存在的未定义的变量(如外部变extern,也可以是函数)

不执行解析,也就是不解析这个变量的地址

rtld_new:与rtld_lazy 不同,在dlopen()返回前,解析处每个未定义的变量的地址,如果解析不出来,dlopen会返回null,错位为"undefined symbol:xxx..."

rtld_global:是库中被解析出来的变量在随后的其它链接库中也可以使用,即全局有效。

2、void *dlsym(void *handle, char *symbol)

根据动态链接库的句柄与函数名,返回函数名对应的函数的地址。

3、int dlclose(void *handle)

关闭动态链接库,handle是调用dlopen函数库的句柄

[1] [2] 下一页


Tag: 静态库 ,动态库



文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。