Makefile的基本用法

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命令。

猜你喜欢

转载自blog.csdn.net/caoj_huangy/article/details/86674241