我自己写Makefile, 里面注释了一些写法, 希望能帮到别人。
# make一些规则 ############################################################################ # $@ : 表示目标 # $^ : 表示所有的依赖 # $< : 表示第一个依赖 # # = : 使用=进行赋值, 变量的值是整个Makefile中最后被指定的值 # := : 使用:=进行赋值, 表示直接赋值 # ?= : 使用?=进行赋值, 表示如果该变量没有被赋值, 则赋予等号后的值 # += : 使用+=进行赋值, 和平时写代码的理解一样, 表示将等号后面的值添加到前面的变量 # ############################################################################ ############################ 定义一些变量: 开始 ############################ cc := gcc cflags := -O0 -Wall -g objs := main_run.o\ general_header.o\ ode_forward_euler.o\ ode_backward_euler.o\ ode_trapezoid.o # 定义变量dep_files: 保存所有的依赖(包括根据.h依赖所生成的依赖表.d文件) dep_files := $(patsubst %, %.d, $(objs)) # 判断变量dep_files: 判断该变量中的文件是否存在, 得到真实存在的文件 dep_files := $(wildcard $(dep_files)) ############################ 定义一些变量: 结束 ############################ ############################ 编译目标文件: 开始 ############################ main_run: $(objs) $(cc) $(cflags) $^ -lm -o $@ # 判断变量dep_files是否为空, 如果不是空, 把变量dep_files中的依赖引入到Makefile中 ifneq ($(dep_files),) include $(dep_files) endif # -MD -MF: 在编译源文件时, 生成依赖规则.d文件(包括.h) $(objs): %.o: %.c $(cc) $(cflags) -c $< -MD -MF $@.d -o $@ ############################ 编译目标文件: 结束 ############################ # .PHONY: xxx : 明确说明, xxx命令与当前编译的目录中的同名文件无关 .PHONY: clean # 设置该标签用于清楚.o和目标运行文件 clean: rm $(objs) $(dep_files) main_run标签:files,objs,变量,dep,Makefile,############################,帮到,写法 From: https://www.cnblogs.com/weitao-miao/p/16928812.html