第十部分 使用 make 更新函数库文件

  函数库文件也就是对 Object 文件(程序编译的中间文件)的打包文件。在 Unix 下,一般是由命令ar来完成打包工作。

一、函数库文件的成员

  一个函数库文件由多个文件组成,你可以使用如下格式指定函数库文件及其组成:

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)

二、函数库成员的隐含规则

  当 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

  还有一个变量要注意的是$%,这是专属函数库文件的自动化变量,有关其说明请参见 “自动化变量” 一节。

三、函数库文件的后缀规则

  你可以使用 “后缀规则” 和 “隐含规则” 来生成函数库打包文件,如:

.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

四、注意事项

  在进行函数库打包文件生成时,请小心使用 make 的并行机制(-j参数)。如果多个ar命令在同一时间运行在同一个函数库打包文件上,就很可能损坏这个函数库文件。所以,在 make 未来的版本中,应该提供一种机制来避免并行操作发生在函数打包文件上。
  但就目前而言,你还是应该尽量不要使用-j参数。

你可能感兴趣的:(《跟我一起写Makefile,陈皓》纯手码重置版,Makefile)