1.使用ar -rc命令生成自己的静态库。假设有如下代码hello.c,需要将其生成为libhello.a
hello.c
#include <stdio.h>
void h1(void)
{
printf("%s\n", __FUNCTION__);
}
使用makefile生成libhello.a
libhello.a: hello.o
ar -rc libhello.a hello.o
上述可以简化成
libhello.a: hello.o
ar -rc $@ $^
2.在main.c中引用libhello.a。假设main.c中有如下代码
#include "hello.h"
int main(int argc, char const *argv[])
{
h1();
return 0;
}
Makefile如下
main:main.o
gcc -o $@ $^ -lhello -L. #-lhello表示链接到libhello.a, -L.表示在当前目录下查找libhello.a,
libhello.a: hello.o
ar -rc $@ $^
3.把libhello.a也加入main的依赖中,这样如果更新了库文件,就会重新编译main
main:main.o libhello.a
gcc -o $@ $^ -lhello -L.
libhello.a: hello.o
ar -rc $@ $^
执行make,./main就可以看到运行结果了。
4.生成自己的动态库.有如下代码world.c,将其生成libworld.so
#include <stdio.h>
void w1(void)
{
printf("hello world %s\n", __FUNCTION__);
}
Makefile如下
libworld.so:world.c
gcc -c $^ -o world.o -fPIC #-fPIC表示位置无关码
gcc -o $@ world.o -shared #-shared表示以共享库方式链接
main.c可以改成
#include "hello.h"
#include "world.h"
int main(int argc, char const *argv[])
{
h1();
w1();
return 0;
}
全部makefile可以写成
main:main.c libhello.a libworld.so
gcc -o $@ $^ -L.
libhello.a: hello.o
ar -rc $@ $^
libworld.so:world.c
gcc -c $^ -o world.o -fPIC
gcc -o $@ world.o -shared
经过make后,运行./main,会提示
./main: error while loading shared libraries: libworld.so: cannot open shared object file: No such file or directory
因为共享库一般是预先加载到内存中的,自己创建的只能手动加入了。
复制 libworld.so 到/usr/lib 目录下即可,或者把库文件所在的目录手动导入到变量LD_LIBRARY_PATH中:export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:库文件所在目录