<b>Linux中若何成立静态库和动态库</b>[Linux安全]
本文“<b>Linux中若何成立静态库和动态库</b>[Linux安全]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
函数库分为静态库和动态库两种.
静态库在程序编译时会被衔接到目标代码中,程序运行时将不再需求该静态库.
动态库在程序编译时并不会被衔接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需求动态库存在.
程序1: hello.h
#ifndef HELLO_H
#define HELLO_H
void hello(const char *name);
#endif //HELLO_H
程序2: hello.c
#include
void hello(const char *name)
{
printf("Hello %s!\n", name);
}
程序3: main.c
#include "hello.h"
int main()
{
hello("everyone");
return 0;
}
无论动态库还是静态库都需求用到.o文件来生成,先编译生成.o文件.
# gcc -c hello.c
1:成立静态库
静态库文件名的命名标准是以lib为前缀,紧接着跟静态库名,扩大名为.a.比方:我们将成立的静态库名为myhello,则静态库文件名就是libmyhello.a.
# ar cr libmyhello.a hello.o
利用静态库:只需求在你的源程序中加入包含你所需求利用到的函数的声明(即包含头文件),然后在gcc生成目标文件时刻指明静态库就OK了(除非你包含的头文件在/usr/include,库文件在尺度库/usr/lib,/lib下,不然你得显示指明他们的途径)
# gcc -o hello main.c -L. -lmyhello
# ./hello
Hello everyone!
删除静态库文件运行./hello,程序正常运行,阐明静态库公用函数已经链接到目标文件.
2: 操纵.o文件成立动态库
动态库文件扩大名为.so.
# gcc -shared -fPCI -o libmyhello.so hello.o
动态库的利用与静态库利用方法一样
# gcc -o hello main.c -L. -lmyhello
# ./hello
./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory
哦!出错了.快看看错误提醒,本来是找不到动态库文件libmyhello.so.程序在运行时,会在/usr/lib和/lib等目录中查找需求的动态库文件.若找到,则载入动态库,不然将提醒近似上述错误而终止程序运行.
若何找到生成的动态库有3种方法:
1)把库拷贝到/usr/lib和/lib目录下.
(2)在LD_LIBRARY_PATH环境变量中加上库所在途径.
比方动态库libhello.so在/home/example/lib目录下:
$export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/example/lib
(3) 改正/etc/ld.so.conf文件,把库所在的途径加到文件末尾,并履行ldconfig革新.这样,加入的目录下的全部库文件都可见.
当静态库和动态库同名时, gcc号令将优先利用动态库.
函数库分为静态库和动态库两种.
静态库在程序编译时会被衔接到目标代码中,程序运行时将不再需求该静态库.
动态库在程序编译时并不会被衔接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需求动态库存在.
程序1: hello.h
#ifndef HELLO_H
#define HELLO_H
void hello(const char *name);
#endif //HELLO_H
程序2: hello.c
#include
void hello(const char *name)
{
printf("Hello %s!\n", name);
}
程序3: main.c
#include "hello.h"
int main()
{
hello("everyone");
return 0;
}
无论动态库还是静态库都需求用到.o文件来生成,先编译生成.o文件.
# gcc -c hello.c
1:成立静态库
静态库文件名的命名标准是以lib为前缀,紧接着跟静态库名,扩大名为.a.比方:我们将成立的静态库名为myhello,则静态库文件名就是libmyhello.a.
# ar cr libmyhello.a hello.o
利用静态库:只需求在你的源程序中加入包含你所需求利用到的函数的声明(即包含头文件),然后在gcc生成目标文件时刻指明静态库就OK了(除非你包含的头文件在/usr/include,库文件在尺度库/usr/lib,/lib下,不然你得显示指明他们的途径)
# gcc -o hello main.c -L. -lmyhello
# ./hello
Hello everyone!
删除静态库文件运行./hello,程序正常运行,阐明静态库公用函数已经链接到目标文件.
2: 操纵.o文件成立动态库
动态库文件扩大名为.so.
# gcc -shared -fPCI -o libmyhello.so hello.o
动态库的利用与静态库利用方法一样
# gcc -o hello main.c -L. -lmyhello
# ./hello
./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory
哦!出错了.快看看错误提醒,本来是找不到动态库文件libmyhello.so.程序在运行时,会在/usr/lib和/lib等目录中查找需求的动态库文件.若找到,则载入动态库,不然将提醒近似上述错误而终止程序运行.
若何找到生成的动态库有3种方法:
1)把库拷贝到/usr/lib和/lib目录下.
(2)在LD_LIBRARY_PATH环境变量中加上库所在途径.
比方动态库libhello.so在/home/example/lib目录下:
$export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/example/lib
(3) 改正/etc/ld.so.conf文件,把库所在的途径加到文件末尾,并履行ldconfig革新.这样,加入的目录下的全部库文件都可见.
当静态库和动态库同名时, gcc号令将优先利用动态库.
以上是“<b>Linux中若何成立静态库和动态库</b>[Linux安全]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |