开发中,我们有时候需要把相关的功能模块做成库的时候提供给其他人使用,我们谈一下静态库的方式。
方式一
//lib_a1.c
#include <stdio.h>
int a1_fun()
{
printf("a1_fun\n");
return 0;
}
//lib_a2.c
int a1_fun();
int a2_fun()
{
a1_fun();
return 0;
}
//main.c
#include <stdio.h>
int a2_fun();
int main()
{
a2_fun();
return 0;
}
#Makefile
all:main
lib_a1.a: lib_a1.o
ar rcs $@ $<
lib_a2.a: lib_a2.o
ar rcs $@ $<
main: main.o lib_a1.a lib_a2.a
gcc -o $@ main.o -l_a2 -l_a1 -L.
%.o : %.c
gcc -c $< -o $@
clean:
rm -rf *.o *.a *.so main
代码很简单,我们目标静态库是lib_a2.a,它本身依赖lib_a1.a,编译lib_a2.a的时候我们没有链接-la1,所以我们交付静态库的时候我们需要把lib_a2和lib_a1(一般为开源库,这里为了方便,自定义了一个简单静态库)同时交付出去,同时链接的时候还需要注意顺序问题(可以参考本系列的静态库链接顺序问题)。
方式二
#Makefile
all:main
lib_a1.a: lib_a1.o
ar rcs $@ $<
lib_a2.a: lib_a2.o lib_a1.a
ar x lib_a1.a
ar rcs $@ *.o
main: main.o lib_a1.a lib_a2.a
gcc -o $@ main.o -l_a2 -L.
%.o : %.c
gcc -c $< -o $@
clean:
rm -rf *.o *.a *.so main
编译运行:
# make clean;make
rm -rf *.o *.a *.so main
gcc -c main.c -o main.o
gcc -c lib_a1.c -o lib_a1.o
ar rcs lib_a1.a lib_a1.o
gcc -c lib_a2.c -o lib_a2.o
ar x lib_a1.a
ar rcs lib_a2.a *.o
gcc -o main main.o -l_a2 -L.
# ./main
a1_fun
按照这个静态库封装的方式,我们交互的时候不再需要提供lib_a1.a