Linux下的系统编程——makefile入门

前言:

或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义。

一、makefile: 管理项目。

设置文件add.c  div1.c  sub.c   hello.c

Linux下的系统编程——makefile入门_第1张图片

 

    命名:makefile     Makefile  --- make 命令

    1.  1 个规则:

        目标:依赖条件

                        (一个tab缩进)命令

makefile中的规则

Linux下的系统编程——makefile入门_第2张图片

Linux下的系统编程——makefile入门_第3张图片

(1)目标的时间必须晚于依赖条件的时间,否则,更新目标

(2)依赖条件如果不存在,找寻新的规则去产生依赖条件。

    ALL:指定 makefile 的终极目标。

        (目的是确定最终退出的目标)

Linux下的系统编程——makefile入门_第4张图片

 


    2.  2 个函数:

        (1)src = $(wildcard ./*.c)

        匹配当前工作目录下的所有.c 文件。将文件名组成列表,赋值给变量 src。  src = add.c sub.c div1.c 

        (2)obj = $(patsubst %.c, %.o, $(src))

        将参数3中,包含参数1的部分,替换为参数2。 obj = add.o sub.o div1.o

Linux下的系统编程——makefile入门_第5张图片Linux下的系统编程——makefile入门_第6张图片

            clean:    (没有依赖)

        -rm -rf $(obj) a.out    “-”:作用是,删除不存在文件时,不报错。顺序执行结束。

Linux下的系统编程——makefile入门_第7张图片

Linux下的系统编程——makefile入门_第8张图片

 

    3.  3 个自动变量:

        (1)$@

                        在规则的命令中,表示规则中的目标。

        (2)$^

                        在规则的命令中,表示所有依赖条件。

        (3)$<

                        在规则的命令中,表示第一个依赖条件。如果将该变量应用在模式规则中,它可将

                依赖条件列表中的依赖依次取出,套用模式规则。

Linux下的系统编程——makefile入门_第9张图片Linux下的系统编程——makefile入门_第10张图片

 

4.模式规则:

        %.o:%.c
           gcc -c $< -o %@

Linux下的系统编程——makefile入门_第11张图片Linux下的系统编程——makefile入门_第12张图片

 

    (1)静态模式规则:

        $(obj):%.o:%.c
           gcc -c $< -o %@    

Linux下的系统编程——makefile入门_第13张图片

Linux下的系统编程——makefile入门_第14张图片

    (2)伪目标:

        .PHONY: clean ALL

Linux下的系统编程——makefile入门_第15张图片

     参数:
        -n:模拟执行make、make clean 命令。

        -f:指定文件执行 make 命令。                xxxx.mk

Linux下的系统编程——makefile入门_第16张图片

 Linux下的系统编程——makefile入门_第17张图片

 

你可能感兴趣的:(linux,服务器,makefile入门,Linux系统编程,ubuntu,编辑器,c语言)