makefile 目标:依赖文件写法

简要说下makefile的一个基本格式:

目标:依赖文件(目标)

【tab】命令

“目标” :是你要生成的或操作的命令的索引

“依赖” :是生成目标依赖的文件或目标【依赖文件的任一处改动,将导致已存在的目标文件过期】

“命令” :是为了生成目标的给shell执行的命令

需要注意的是,依赖的作用:

【依赖文件的任一处改动,将导致已存在的目标文件过期】

依赖的作用就是决定目标是否过期,是否需要重新编译。

举个例子:

#include <stdio.h>
#include "mylib1.h"
#include "mylib2.h"
 
int main(int argc, char argv[]){
    printf("hello world!\n");
}

我的makefile可以写成

helloworld : stdio.h mylib1.h mylib2.h other.o
gcc -o helloworld helloworld.c

也可以写成

helloworld : other.o
 gcc -o helloworld helloworld.c

前者希望在stdio.h mylib1.h,mylib2.h,other.o 改变的时候重新编译helloworld.c,后者希望仅仅在other.o改变的时候重新编译helloworld.c。

因此,

你想helloworold在什么改变的时候重新编译,就把什么写在依赖里。这就是依赖,并不死板的规定所有头文件必须写在依赖里。(不过一般而言,为了目标能正常执行,都希望自己写得头文件发生了改变,重新编译目标)

========================================================================================

依赖的另外一个常做用途是:执行指定的目标

例如:

.PHONY: all

all : helloworld clean

helloworld:helloworld.o

gcc helloworld.o -o helloworld

helloworld.o:

gcc -c helloworld.c

clean:

rm helloworld.o

all作为终极目标(即makefile的最上面的第一个目标),依赖helloworld和clean,因此,执行生成all目标前(实际上由于all目标没有命令,因此在处理完依赖后直接退出,并没有all生成),会先执行helloworld和clean目标。

上一篇:​Python 中的数字到底是什么?


下一篇:python-集合类型set与frozenset(操作符、方法、内置函数)