makefile文件编写规则

目标(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: -----------------------------------------

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值