Linux操作系统中连接库如何生
库有动态与静态两种,动态通常用。so为后缀,静态用。a为后缀。例如:libhello。so libhello。a
为了在同一系统中使用不同版本的库,可以在库文件名后加上版本号为后缀,例如: libhello。 so。1。0,由于程序连接默认以。so为文件后缀名。所以为了使用这些库,通常使用建立符号连接的方式。
ln -s libhello。so。1。0 libhello。so。1
ln -s libhello。 so。1 libhello。so
使用库
当要使用静态的程序库时,连接器会找出程序所需的函数,然后将它们拷贝到执行文件,由于这种拷贝是完整的,所以一旦连接成功,静态程序库也就不...全部
库有动态与静态两种,动态通常用。so为后缀,静态用。a为后缀。例如:libhello。so libhello。a
为了在同一系统中使用不同版本的库,可以在库文件名后加上版本号为后缀,例如: libhello。
so。1。0,由于程序连接默认以。so为文件后缀名。所以为了使用这些库,通常使用建立符号连接的方式。
ln -s libhello。so。1。0 libhello。so。1
ln -s libhello。
so。1 libhello。so
使用库
当要使用静态的程序库时,连接器会找出程序所需的函数,然后将它们拷贝到执行文件,由于这种拷贝是完整的,所以一旦连接成功,静态程序库也就不再需要了。然而,对动态库而言,就不是这样。
动态库会在执行程序内留下一个标记‘指明当程序执行时,首先必须载入这个库。由于动态库节省空间,linux下进行连接的缺省操作是首先连接动态库,也就是说,如果同时存在静态和动态库,不特别指定的话,将与动态库相连接。
现在假设有一个叫hello的程序开发包,它提供一个静态库libhello。a 一个动态库libhello。so,一个头文件hello。h,头文件中提供sayhello()这个函数
/* hello。
h */
void sayhello();
另外还有一些说明文档。这一个典型的程序开发包结构
1。与动态库连接
linux默认的就是与动态库连接,下面这段程序testlib。c使用hello库中的sayhello()函数
/*testlib。
c*/
#include
#include
int main()
{
sayhello();
return 0;
}
使用如下命令进行编译
$gcc -c testlib。c -o testlib。
o
用如下命令连接:
$gcc testlib。o -lhello -o testlib
在连接时要注意,假设libhello。o 和libhello。a都在缺省的库搜索路径下/usr/lib下,如果在其它位置要加上-L参数
2。
与静态库连接麻烦一些,主要是参数问题。还是上面的例子:
$gcc testlib。o -o testlib -WI,-Bstatic -lhello
注:这个特别的"-WI,-Bstatic"参数,实际上是传给了连接器ld。
指示它与静态库连接,如果系统中只有静态库当然就不需要这个参数了。
如果要和多个库相连接,而每个库的连接方式不一样,比如上面的程序既要和libhello进行静态连接,又要和libbye进行动态连接,其命令应为:
$gcc testlib。
o -o testlib -WI,-Bstatic -lhello -WI,-Bdynamic –lbye
3。动态库的路径问题
为了让执行程序顺利找到动态库,有三种方法:
(1)把库拷贝到/usr/lib和/lib目录下。
(2)在LD_LIBRARY_PATH环境变量中加上库所在路径。例如动态库libhello。so在/home/ting/lib目录下,以bash为例,使用命令:
$export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/ting/lib
(3) 修改/etc/ld。
so。conf文件,把库所在的路径加到文件末尾,并执行ldconfig刷新。这样,加入的目录下的所有库文件都可见。收起