目标(target): 依赖(prerequiries)...
tap键 规则命令(command)
- 目标(target)通常是要产生的文件的名称,目标的例子是可执行文件或OBJ文件。目标也可是一个执行的动作名称,诸如‘clean’(仅仅表达动作的目标称为假想目标)。
- 依赖是用来输入从而产生目标的文件,一个目标经常有几个依赖。
- 命令是make执行的动作,一个规则可以含有几个命令,每个命令占一行。
注意:每个命令行前面必须是一个Tab字符,即命令行第一个字符是Tab。这是不小心容易出错的地方。
编译参数
-I(大i) 包含头文件路径
-L 包含库路径
-l (小L) 指定库文件名
-o 目标文件名
-g 用于gbd调试
-f 编译指定名字的makefile文件
-c 只编译不链接(产生.o文件)
-wall 显示所有警告
-D 指定宏编译
-lstdc++ 编译c++代码
1、通配符
-
patsubst: 替换通配符
$(patsubst <pattern>,<replacement>,<text> )
例子:$(patsubst %.c,%.o, 1.c 2.c)
名称:模式字符串替换函数——patsubst。
功能:查找text中的单词(单词以“空格”、“Tab”或“回车”“换行”分隔)是否符合模式pattern,如果匹配的话,则以替换。
这里,pattern可以包括通配符“%”,表示任意长度的字串。如果replacement中也包含“%”,那么,replacement中的这个“%”将是pattern中的那个“%”所代表的字串。
(可以用“\”来转义,以“%”来表示真实含义的“%”字符)
返回:函数返回被替换过后的字符串。
例子:把字串“1.c,2.c”符合模式[%.c]的单词替换成[%.o],返回结果是“1.o 2.o”。
-
wildcard: 扩展通配符
SOURCES = $(wildcard *.cpp)
例子:SOURCES = $(wildcard *.cpp) $(wildcard inc/*.cpp)
wildcard得到指定目录下所有的C语言源程序文件名。
例子:编译当前目录以及子目录inc的下所有.c文件。
-
notdir: 去除路径
OBJECTS = $(notdir $(patsubst %.c,%.o,$(SOURCES)))
notdir去除文件路径信息。
2、变量符号$
- $符号表示取变量的值,当变量名多于一个字符时,使用"( )"
- $@:表示目标文件。
- $^:表示所有依赖文件。
- $<:表示第一个依赖文件。 如果是模式规则,会将依赖条件依次取出。
3、回显
- @echo
all:
@echo $(src)
@echo $(dir)
@echo $(obj)
@echo "end"
- warning
$(warning -----------------------------------------)
$(warning OBJECTS:$(OBJECTS))
$(warning TARGET:$(TARGET))
$(warning -----------------------------------------)
输出:
makefile:32: -----------------------------------------
makefile:33: OBJECTS:main.o
makefile:34: TARGET:opencv_test
makefile:35: -----------------------------------------