在linux上编程离不开写Makefile,简单来说Makfile就是写一个文件,告诉make程序先编译哪个文件,再编译哪个文件,头文件都是哪些。
本文基于GNU Make的Makefile官方文档
先介绍一下Makefile中rules的书写格式:
target...:prerequisites...
recipe
...
...
target一般是一个我们要生成的文件的名称,但也可以是一个动作例如clean
prerequisites一般是我们用来生成target的文件
recipe是一个动作,可能有多行recipe,注意:recipe前面不是敲几个空格,而是一个tab键,这是非常容易犯错的 make把recipe动作施加到prerequisites上。
一个简单的Makefile只包含rules。
接下来按照上面的那个target——prerequisites——recipe的格式看一下官方给出的例子:
edit : main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
cc -o edit main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
main.o : main.c defs.h
cc -c main.c
kbd.o : kbd.c defs.h command.h
cc -c kbd.c
command.o : command.c defs.h command.h
cc -c command.c
display.o : display.c defs.h buffer.h
cc -c display.c
insert.o : insert.c defs.h buffer.h
cc -c insert.c
search.o : search.c defs.h buffer.h
cc -c search.c
files.o : files.c defs.h buffer.h command.h
cc -c files.c
utils.o : utils.c defs.h
cc -c utils.c
clean :
rm edit main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
注意,\反斜杠意味着分割一个很长的句子,方便人们阅读
稍微用心看一下就可以发现这里有如下几个target:
edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o clean
后面跟着的prerequisites和recipe就不用我多说了吧,edit由多个.o文件生成,.o由多个.c文件和.h文件生成,具体如何生成的就是例如cc -c utils.c这种recipe说明的
值得注意的是clean作为target 的时候不需要有prerequisites,因为clean是一个动作。
到此为止,大家应该就可以写一个只包含rules的简单Makefile了,当然Makefile还有更复杂的书写方式,但大家已经迈出了第一步