Makefile:如何写目标依赖

本文并不是Makefile的教程,仅是本人学习时的感悟。

Makefile的基本格式

目标:依赖文件(or 目标)
[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目标,而后者仅仅希望检查other.o的修改。

目标依赖往往还有另外一种用法,用于执行其他目标。例如

.PHONY: all clean target

all: target clean

target: helloworld.o
    gcc helloworld.o -o helloworld

helloworld.o:
    gcc -c helloworld.c

clean:
    rm helloworld.o

执行all目标的时候,依赖另外两个目标targetclean。在执行all目标前,会优先执行目标targetclean

怎么判断all依赖的是目标还是文件

.PHONY: all

all: test
    @echo in all

test:
    @echo in test

执行这个Makefile时,当前目录下有无test文件会有两个不同的执行结果

[[email protected]:24 tmp]$ll
总用量 4.0K
1186807 -rw-r--r-- 1 gmpy gmpy 57 4月   5 11:20 Makefile
[[email protected]:24 tmp]$make
echo in test
in test
echo in all
in all
[[email protected]:24 tmp]$touch test #创建test文件
[[email protected]:24 tmp]$make
echo in all
in all
[[email protected]:24 tmp]$

总结来说,判断依赖是目标还是文件,有以下两个规则:

  1. 优先检查当前目录下是否有同名文件,有则文件,无则目标
  2. .PHONY 标识的都是(伪)目标,不再检查文件是否存在

原文地址:https://www.cnblogs.com/gmpy/p/10658304.html

时间: 2024-11-05 21:53:55

Makefile:如何写目标依赖的相关文章

makefile自动生成目标与依赖的关系

有main.c: 1 #include <stdio.h> 2 #include "command.h" 3 4 int main(int argc, const char *argv[]) 5 { 6 printf("run in main\n"); 7 return 0; 8 } commad.h: 1 #ifndef __COMMAND_H__ 2 #define __COMMAND_H__ 3 4 #define PI 3.14159 5 6 #

Makefile 7——自动生成依赖关系 三颗星

后面会介绍gcc获得源文件依赖的方法,gcc这个功能就是为make而存在的.我们采用gcc的-MM选项结合sed命令.使用sed进行替换的目的是为了在目标名前加上"objs/"前缀.gcc的-E选项,预处理.在生成依赖关系时,其实并不需要gcc编译源文件,只要预处理就可以获得依赖关系了.通过-E选项,可以避免生成依赖关系时gcc发出警告,以及提高依赖关系的生成效率. 现在,已经找到自动生成依赖关系的方法了,那么如何将其整合到我们complicated项目的Makefile中呢?自动生成

(转)makefile中的自动依赖规则

Makefile生成自动依赖的方法有两种: 1.  将所有.o文件的依赖关系写入单独文件,然后在Makefile中调用该文件 2.  每个.c文件对应一个.d文件,将依赖关系写入.d文件中 一.对于第一种方法,Makefile的写法如下: #file start CC = gcc SRCS := $(wildcard *.c) OBJS := $(patsubst %.c,%.o, $(SRCS)) all: main main: $(OBJS) $(CC) -o main $(OBJS) .d

Makefile一个cpp文件依赖于多个header文件的陷阱

我一直以为,如果一个A.cpp文件中有多少条 #include "xxx.h"指令,在写Makefile的时候A.obj的依赖项除了A.cpp之外,就是A.cpp之内所有的 xxx.h 比如,如果A.cpp中有 #include "A.h" #include "B.h" #include "C.h",那么在Makefile中就有:A.obj: A.cpp A.h B.h C.h 但是 下面的例子是说明了,上面的想法是错误的 先

【学习记录】关于makefile而进行的互联网学习技巧练习及学习笔记和学习心得记录(vs2010)

我也不知道作为一个完全的windows平台下的不怎么专业的软件工程学生,看到<Accelerated C++>的源代码,第一反应是:哦!我应该用make生成工程文件.然后我愉快的用AOL开始搜索相关资料. 然并卵!我一定是被什么奇怪的生物附身了.我应该直接用vs创建项目->导入文件.然后……ctrl+F5.多么完美. 可是……以下: [教程]来自于云风大大的blog(云风的 BLOG) IDE 不是程序员的唯一选择(一) 以及后面的(二)(三)(四) 以及大大写了一篇半,只为了说明用cl

Linux下make与makefile

make 用来解析 makefile 文件 make 的选项: -d 显示调试信息 -f 文件 默认是从 makefile 或 Makefile 中读取依赖信息,用该选项可更改文件 -h 显示所有 makefile 的 help 信息 -n 显示 makefile 执行命令的顺序,但不执行 -s 运行时不显示任何信息 makefile 格式: 目标:依赖列表 <Tab>命令列表 目标通常是指要生成的文件的名称,可以使可执行文件或obj文件,也可以是一个执行的动作名称,如clean .依赖是用来

Makefile文件简单整理

.PHONY:clean main:hello.o gcc -o main hello.c hello.o:hello.c gcc -c hello.c clean: rm -f hello.o main --------------------------------------- makefile伪目标 只包含目标,没有任何依赖的目标称为伪目标.上例中clean即为伪目标 使用 .PHONY 将  clean 声明为伪目标 ----------------------------------

转:跟我一起写Makefile (PDF重制版)

原文地址:http://seisman.info/how-to-write-makefile.html 其它一些问题  不妨看一下:http://blog.csdn.net/huyansoft/article/details/8924624 简化版  不妨看一下:http://blog.chinaunix.net/uid-26980210-id-3244651.html 跟我一起写 Makefile (PDF 重制版)By [email protected]作者: 陈皓2014 年 03 月 0

跟我一起写 Makefile ---&lt;转&gt;

http://blog.csdn.net/augusdi/article/details/7348375 概述 —— 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂.这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义.特别在Unix下的软件编译,你就不能不自己写makefile了,会不会写ma