Makefile是一个基于UNIX的编译工具,其功能强大,编写简便。
1、首先理解一下它的工作过程:
第一步:编译 把源文件编译成中间代码文件,win下就是.obj文件,unix下就是.o文件。
此过程就是编译。
第二步:链接 将便已生成的大量object 文件合成一个可执行文件。
此过程就是链接。
2、执行Makefile有几个小规则:
如果这个工程没有编译过,执行make就会编译链接所有的源文件。
如果修改了.c文件,执行make就会只编译链接这几个修改的.c文件。
如果修改了.h文件,执行make就会编译链接使用过.h的多有源文件。
3、编写规则:
套路:
target : file
command
。。。
target是一个目标文件,可以是中间件也可以是可执行文件。
file是生成target所需要的文件。
command是需要执行的shell命令。
简单理解就是一种依赖关系,使用Makefile大部分目的是为得到可执行文件,
那么target就是最终的可执行文件,根据GCC规则知道,可执行文件的生成需
要依赖于.o文件,而.o文件的生成需要依赖于源文件。
注意:Makefile语句的缩进必须使用tab键。
4、一个简单的事例:
我们有5个.c文件,1个.h文件,编译个Makefile文件。
main : main.o add.o mul.o sub.o div.o
gcc -g -o main main.o add.o mul.o sub.o div.o
main.o : main.c header.h
gcc -c main.c
add.o : add.c header.h
gcc -c add.c
sub.o : sub.c header.h
gcc -c sub.c
div.o : div.c header.h
gcc -c div.c
.PHONY:clean
clean:
rm -f *.o main
Makefile文件编写完成,在当前目录下执行make命令,便直接生成可执行文件main。
执行make clean,便执行rm -f *.o main命令。