Makefile使用(7)-更新函数库文件

函数库文件也就是对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命令在同一个函数库打包文件上,就很有可能损坏这个函数库文件。

results matching ""

    No results matching ""