函数库文件也就是对Object文件(程序编译的中间文件)的打包文件。在Unix下,通常是由命令ar来完成打包工作。
5.10.1函数库文件的成员
一个函数库文件由多个文件组成。可以以如下格式指定函数库文件及其组成:
archive(member)
这不是一个命令,而是一个目标和依赖的定义。通常来说,这些用法基本上就是为了ar命令来服务的。如:
foolib(hack.o):hack.o
arcrfoolibhack.o
假如要指定多个member,那就以空格分开,如:
foolib(hack.okludge.o)
其等价于:
foolib(hack.o)foolib(kludge.o)
还可以使用Shell的文件键值来定义,如:
foolib(*.o)
5.10.2函数库成员的蕴涵规则
当make搜索一个目标的蕴涵规则时,一个特点是,假如这个目标是“a(m)”形式的,其会把目标弄成“(m)”。于是,倘若成员是“%.o”的模式定义,但是假如使用makefoo.a(bar.o)的方式调用makefile文件linux操作系统版本,蕴涵规则会去找bar.o的规则;若果没有定义bar.o的规则,内建蕴涵规则生效,make会去找bar.c文件来世成bar.o。假如找得到,make执行的命令大致如下:
gcc-cbar.c-obar.o
arrfoo.abar.o
rm-fbar.o
还有一个变量要注意的是“$%”linux环境变量,这是专属函数库文件的手动化变量。
5.10.3函数库文件的后缀规则
可以使用后缀规则和蕴涵规则来世成函数库打包文件,如:
c.a:
$(gcc)$(CFLAGS)$(CPPFLAGS)-c$<-o$*.o
$(AR)r$@$*.o
$(RM)$*.o
其等效于:
(%.o):%.c
$(CC)$(CFLAGS)$(CPPFLAGS)-c$<-o$*.o
$(AR)r$@$*.o
$(RM)$*.o
5.10.4注意事项
在生成函数库打包文件时,请当心使用make的并行机制(-j参数)。假如多个ar命令在同一时间运行在同一个函数库打包文件上,就很有可能受损这个函数库文件。所以,在make未来的版本中,应当提供一种机制来防止并行操作发生在函数打包文件上。但就目前而言,还是尽量不要使用-j参数。
以上基本上就是GNUmake的makefile文件的所有细节了。无论哪些样的make,都是以文件的依赖性为基础的,其基本都是秉持一个标准的。对于前述所有的make的细节linux中makefile文件,不但可以借助make这个工具来编译程序,还可以借助make来完成其他的工作。由于规则中的命令可以是任何Shell之下的命令,所以,在Linux下,不一定只使用程序语言的编译器,还可以在makefile文件中书写其他的命令,如tar、awk、mail、sed、cvs、compress、ls、rm、yacc、rpm、ftp等linux中makefile文件,来完成例如程序打包、程序备份、制作程序安装包、提交代码、使用程序模板、合并文件等众多功能,如文件操作、文件管理、编程开发设计,或是其他一些异想天开的东西。