分类: C/C++
2009-08-07 10:25:33
一、静态库的创建和使用:
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函数库的句柄
4、const char *dlerror(void)
动态库链接库执行失败时,dlerror返回错误信息,若执行成功,则返回NULL
例子:
|
注意:dlopen("./libttt.so", RTLD_LAZY),的目录是在当前目录下,如果不在当前目录下,程序运行错误
共享库进行更新或安装新库后,必须运行ldconfig命令更新/etc/ld.conf文件中相应的项
如果使用RPM进行安装,一般会自动进行更新,不过也不能保证这一点。
使用数学库时加上 -lm
gcc -lm
库工具使用:
ldd 工具
ldd 用来显示执行文件需要哪些共享库, 共享库装载管理器在哪里找到了需要的共享库。
这里注意可移植性:
BSD/OS
创建 PIC 的编译器标志是 -fpic.创建共享库的链接器标志是 -shared.
gcc -fpic -c foo.c
ld -shared -o foo.so foo.o
上面方法适用于版本 4.0 的 BSD/OS.
FreeBSD
创建 PIC 的编译器标志是 -fpic.创建共享库的链接器标志是 -shared.
gcc -fpic -c foo.c
gcc -shared -o foo.so foo.o
上面方法适用于版本 3.0 的 FreeBSD.
HP-UX
创建 PIC 的系统编译器标志是 +z.如果使用 GCC 则是 -fpic. 创建共享库的链接器标志是 -b.因此
cc +z -c foo.c
或
gcc -fpic -c foo.c
然后
ld -b -o foo.sl foo.o
HP-UX 使用 .sl 做共享库扩展,和其它大部分系统不同.
IRIX
PIC 是缺省,不需要使用特殊的编译器选项. 生成共享库的链接器选项是 -shared.
cc -c foo.c
ld -shared -o foo.so foo.o
Linux
创建 PIC 的编译器标志是 -fpic.在一些平台上的一些环境下, 如果 -fpic 不能用那么必须使用-fPIC. 参考 GCC 的手册获取更多信息. 创建共享库的编译器标志是 -shared.一个完整的例子看起来象:
cc -fpic -c foo.c
cc -shared -o foo.so foo.o
NetBSD
创建 PIC 的编译器标志是 -fpic.对于 ELF 系统, 带 -shared 标志的编译命令用于链接共享库. 在老的非 ELF 系统里,使用ld -Bshareable.
gcc -fpic -c foo.c
gcc -shared -o foo.so foo.o
OpenBSD
创建 PIC 的编译器标志是 -fpic. ld -Bshareable 用于链接共享库.
gcc -fpic -c foo.c
ld -Bshareable -o foo.so foo.o
Solaris
创建 PIC 的编译器命令是用 Sun 编译器时为 -KPIC 而用 GCC 时为 -fpic.链接共享库时两个编译器都可以用 -G 或者用 GCC 时还可以是 -shared.
cc -KPIC -c foo.c
cc -G -o foo.so foo.o
或
gcc -fpic -c foo.c
gcc -G -o foo.so foo.o
Tru64 UNIX
PIC 是缺省,因此编译命令就是平常的那个. 带特殊选项的 ld 用于链接:
cc -c foo.c
ld -shared -expect_unresolved '*' -o foo.so foo.o
用 GCC 代替系统编译器时的过程是一样的;不需要特殊的选项.
UnixWare
SCO 编译器创建 PIC 的标志是-KPIC GCC 是 -fpic. 链接共享库时 SCO 编译器用 -G 而 GCC 用-shared.
cc -K PIC -c foo.c
cc -G -o foo.so foo.o
or
gcc -fpic -c foo.c
gcc -shared -o foo.so foo.o