跟我一起写 Makefile - 10. 使用 make 更新函数库文件
10. 使用 make 更新函数库文件
函数库文件就是对 Object 文件 (程序编译的中间文件) 的打包文件。在 Unix 下,一般是由命令 ar 来完成打包工作。
10.1 函数库文件的成员
一个函数库文件由多个文件组成。你可以以如下格式指定函数库文件及其组成:
archive(member)
这个不是一个命令,而是一个目标和依赖的定义。一般来说,这种用法基本上就是为了 ar 命令来服务的。例如:
foolib(hack.o) : hack.o
ar cr foolib hack.o
如果要指定多个 member,那就以空格分开,例如:
foolib(hack.o kludge.o)
其等价于:
foolib(hack.o) foolib(kludge.o)
你还可以使用 shell 的文件通配符来定义,例如:
foolib(*.o)
10.2 函数库成员的隐含规则
当 make 搜索一个目标的隐含规则时,一个特殊的特性是,如果这个目标是 a(m) 形式的,其会把目标变成 (m)。如果我们的成员是 %.o 的模式定义,并且如果我们使用 make foo.a(bar.o) 的形式调用 Makefile 时,隐含规则会去找 bar.o 的规则。如果没有定义 bar.o 的规则,那么内建隐含规则生效,make 会去找 bar.c 文件来生成 bar.o。如果找得到的话,make 执行的命令大致如下:
cc -c bar.c -o bar.o
ar r foo.a bar.o
rm -f bar.o
还有一个变量要注意的是 $%,这是专属函数库文件的自动化变量。
10.3 函数库文件的后缀规则
你可以使用后缀规则和隐含规则来生成函数库打包文件,例如:
.c.a:
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $*.o
$(AR) r $@ $*.o
$(RM) $*.o
其等效于:
(%.o) : %.c
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $*.o
$(AR) r $@ $*.o
$(RM) $*.o
10.4 注意事项
在进行函数库打包文件生成时,请小心使用 make 的并行机制 (-j 参数)。如果多个 ar 命令在同一时间运行在同一个函数库打包文件上,就很有可以损坏这个函数库文件。所以在 make 未来的版本中,应该提供一种机制来避免并行操作发生在函数打包文件上。
就目前而言,还是应该不要使用 -j 参数。
Wordbook
GNU Compiler Collection,GCC:GNU 编译器套件
GNU C Compiler,GCC:GNU C 编译器
Microsoft Visual C++,MSVC
Unix / UNIX /ˈjuːnɪks/