linux 高级编程之库的使用

静态库: .a .lib

动态库: .so .dll

差别(静态库中的代码在链接时就已经复制到可执行文件中,执行时不再依赖库,不会自动使用升级后的库,需要重新产生可执行文件。

动态库代码不在可执行文件中,执行时自动加载,库升级后,可执行文件会自动执行时会自动使用库。还有就是代码量的大小)

ar -r libstr.a string.o i2str.o 打包

?

总结:

静态库:

产生库:写若干个c文件(函数或者全局变量,不应该有main),编译(gcc -c ),打包成库(ar -r libxxxx.a 若干个.o ),写一个.h文件(函数或者全局变量的声明)

*多文件:把一个.c 切成多个,#include每个文件里一份,为每个.c写一个.h,存放.c文件中的函数和全局变量的声明。

产生可执行文件:写c程序,#include 库的头文件,可以使用库里面的函数和变量。gcc xxx.c libxxx.a ,或者 gcc xxx.c -lxxx -L库文件所在目录,或者 设置环境变量LIBRARY_PATH=库文件所在目录,从而省略前者的-L选项。

执行可执行文件:直接执行可执行文件。

需要的是 xxx.h 和 libxxx.a 不再需要源码。

?

动态库:

产生库:写若干xxx.c文件, gcc -c xxx.c 文件; gcc -fpic -shared -o libxxx.so xxx.o 文件。写一个.h文件。

产生可执行文件:写c程序,#include 库的头文件, gcc -c xxx.c ; gcc xxx.o -lxxxx -L库文件目录或者设置环境变量。

执行可执行文件:先把库文件 libxxx.so复制到 /lib 或者 /usr/lib 中或者 设置环境变量 LD_LIBRARY_PATH=$LD_LIBRARY_PATH,然后执行 ./a.out 即可。如果想永久有效,可以放到 ~/.bashrc 当中,或者放到 /etc/profile 中。

?

升级库: 把产生库的过程重复一遍。如果是动态库,可执行文件自动更新,如果是静态库,需要重复产生可执行文件的过程。新的可执行文件使用的才是新库。

静态库的使用:

下面给出了3种方法:

1、

首先定义 string.c and i2str.c

分别如下:

i2str.c

string.c

然后,编写 头文件 str.h(就是一些函数的声明)

2、打包

编译 string.c 和 i2str.c

gcc -c string.c

gcc -c i2str.c

然后会分别输出 string.o and i2str.o

再然后就是打包工作了。

ar -r libstr.a string.o i2str.o

?

3、打完包之后,就可以使用了

编写usestr.c 程序

对于用户编写的库文件,需要加上 #include "xxxx"

?

4、编译,链接即可。

提供三种方法,可供使用。但不论哪种方法,usestr.c 务必与str.h在一起才行。因为二者之间有依赖关系。

这就是动态库与静态库的差别所在,一般静态库在编译的时候,就把代码加载到程序当中了,而动态库是程序正式运行的时候才去加载文件的。

1)gcc usestr.c -lstr libstr.a 头文件与依赖库同时列出

2)gcc usestr.c -lstr -L. 从当前目录中查找依赖库

gcc usestr.c -lstr -Lmdir 从mdir文件当中查找依赖库,此时 libstr.a 需要放在mdir文件夹中。

3)export LIBRARY_PATH=mdir

gcc usestr.c -lstr 设置环境变量,然后程序会自动的从LIBRARY_PATH中查找静态库。

其中lxxx 表示要链接的libxxx.a 库文件,xxx为库名。-L. 表示在当前目录下找库文件libxxx.a

具体的过程如下面所示:

?

动态库的使用:

1)产生库

gcc -c -fpic xxx1.c xxx2.c

gcc -shared -o libxxx.so xxx1.o xxx2.o

2) 使用

编译时: 编写c程序usexxx.c

方式一:gcc -c usexxx.c ; gcc usexxx.o -lxxx -L.

方式二:gcc -c usexxx.c; gcc usexxx.o -lxxx

+ 设置环境变量 LIBRARY_PATH.

运行时:

方式一:把库文件放到系统标准库目录/usr/lib或者/lib 目录中,就可以运行a.out了。

方式二:设置环境变量LD_LIBRARY_PATH的值为动态库文件所在的目录,然后运行a.out。

?

注意一点:绝对路径没有.点开头,只有相对路径才有。

关键代码:

gcc -c welcome.c

gcc -shared -o libwelcome.so welcome.o

gcc -c usewel.c

gcc usewel.o -lwelcome -L.

cp libwelcome.so /usr/lib 后面的/可有可无

或者

LD_LIBRARY_PATH = $LD_LIBRARY_PATH : .

然后运行 ./a.out 即可。

?

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。