来源:Linux社区 作者:firefoxbug
//hello.c
#include
void print_hello()
{
printf("HelloWorld ");
}
//main.c
#include
#include "hello.h"
int main()
{
print_hello();
printf("%d",HELLO);
return 0;
}
//hello.h
#define HELLO 9999
void print_hello();
其中 hello.c 和 main.c 在同一个目录下, hello.h在上一个目录。
先生成 xxx.o 文件
$ gcc hello.c -c ==> hello.o
$ gcc main.c -c ==> error : no hello.h
$ gcc main.c -c -I ../ ==> main.o -I 指定头文件的搜索目录( I 是大小的 i)
$ ls ==> hello.o main.o hello.c main.c
静态库的生成
$ ar cr libhello.a hello.o ==> libhello.a (注意顺序)
静态库的使用
$ gcc main.o -o main.out -lhello==> error : /usr/bin/ld: cannot find -lhello,意思是找不到库 -l 是小写的L
1.linux下默认gcc搜索是按照LD_LIBRARY_PATH来搜索的,标准库(动态库和静态库)都在 /usr/lib/ 下面
2.-lhello是一种约定,表示搜索 libhello.a 或者 libhello.so 的库,-lXXXX 即 libXXXX.a 或者 libXXXX.so
3. 可以用 -L 来指定加载库的目录
$ gcc main.o -o main.out -L . -lhello ==>出现了main.out,成功!
静态库的测试
$ rm libhello.a -f ==>程序照样能运行,说明静态库是链接进程序的!
动态库的生成
$ gcc hello.c -c -fPIC ==>生成带动态链接信息的obj
$ gcc hello.o -o libhello.so -shared ==> libhello.so
动态库的使用
$ gcc main.o -o main.out -L . -lhello ==> -L指定库所在路径,-lhello指定libhello.a 或者 libhello.so
$ ./main.out ==> error while loading shared libraries: libhello.so: cannot open shared object file: No such file or directory
动态链接库是在程序运行时候去加载的,加载的时候是从标准目录/usr/lib下去寻找的,下面是三种解决方法
1. $ cp libhello.so /usr/lib/ ==> libhello.so拷贝到/usr/lib/下去
2. export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:.
// export LD_LIBRARY_PATH=$LD_LIBRARY_PATH : <path of libxxxx.so>
3 . /etc/ld.so.conf 里面加一行所在库的目录,然后执行 ldconfig
/etc/ld.so.conf文件:除了标准目录(/lib和/usr/lib)之外,链接器和加载器搜索共享库时要检查的其他目录,和这个文件相关的一个命令是:ldconfig
动态库的测试
$ rm libhello.so ==>运行的时候出错,说明程序运行的时候需要库!