MakeFile学习

Makefile编译命令

CC :=gcc

# 每个头文件的路径
INC0 :=./inc ./inc1

# 构造gcc头文件路径命令的字符 $(INC0:%=-I%):表示将INC0指代的字符串中所有匹配到的元素(%:匹配所有)替换为 -I%,
# 即在每个元素前加 -I字符  %看作通配符,可匹配所有字符。
INC :=$(INC0:%=-I%)

# 每个C文件所在的文件,用以构造C文件路径文件名
SRCDIR :=./inc ./inc1 .

#每个需要编译C文件的路径名 用以GCC编译  
# foreach类似于遍历SRCDIR中的每个元素(以空格分开的每个元素),且以dir代表每个元素,
# $(wildcard $(dir)/*.c) 为执行步骤 可以为其他命令,此处是将路径$(dir)下的所有.c文件形成字符集。
SRCF :=$(foreach dir ,$(SRCDIR), $(wildcard $(dir)/*.c))

#由于没有执行make前,没有.o文件,MakeFile需要借助.c文件的路径名生成.o的路径名
# %.c=%.o 将所有以.c结尾的字符元素,替换为以.o结尾
OBJ :=$(SRCF:%.c=%.o)

# 执行rm -f 删除.o文件所需要的对象,此处是删除所有生成的*.o文件
DEL :=$(SRCDIR:%=%/*.o)

# 最终生成执行文件的目标名
TAR :=task

# 使用temp虚假目标,以期执行删除命令,使make进行文件更新,从而执行新的一次make,而不用每次执行make前执行 make clean
all:temp $(OBJ)
	$(CC) $(OBJ) -o $(TAR)
	./$(TAR)
	rm -f $(DEL)
temp:
	rm -f $(DEL)
# 生成所有以.o结尾的目标,所需要的依赖为其对应的.c文件的规则
# $<:指代生成目标所需要的第一个依赖文件的字符   $^:指代生成目标所需要的所有依赖文件字符  $@:指代生成的目标文件
# $(INC):构造的头文件路径字符
%.o:%.c
	$(CC) $(INC) -c $< -o $@
以上为MakeFile编译C语言的基本格式,但目前未能找到MakeFile自动获取到所有文件夹,随之获取所有的.o文件,这样无须我们收到填充文件夹。通过百度得到的是MakeFile并没有直接的命令获取,都需要结助shell。
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值