Makefile编写

命名:makefile Makefile
如果命名为其他名字比如mf,执行命令为make -f mf
1个规则:
ALL:a.out
目标:依赖条件
(一个tab缩进)命令
2个函数
$(wildcard ./*.c):匹配当前工作目录下的所有.c文件。将文件名组成列表,赋值给变量src
( p a t s u b s t (patsubst %.c,%.o, (patsubst(src)):将参数3中,包含参数1的部分,替换为参数2
3个自动变量
$@:在规则的命令中,表示规则中的目标
$^:在规则的命令中,表示所有依赖条件
$<:在规则的命令中,表示第一个依赖条件.如果将该变量应用在模式规则中,它可将依赖条件列表中的依赖依次取出,套用模式规则

1.Makfile同级目录下创建src,inc,bin,obj目录,如果有动态库要链接创建lib目录
2.将.c文件放入到src目录,.h文件放入到inc目录

SRC = ./src
INC = ./inc
BIN = ./bin
OBJ = ./obj

#匹配当前工作目录下的所有.c文件。将文件名组成列表,赋值给变量src
src = $(wildcard $(SRC)/*.c) # ./src/hello.c
#将参数3中,包含参数1的部分,替换为参数2
obj = $(patsubst $(SRC)/%.c, $(OBJ)/%.o, $(src))  # /obj/hello.o
#打印变量
$(info $(src))
$(info $(obj))

inc_path = ./inc
ARGS = -Wall -g


ALL:a.out

a.out:$(obj)
        gcc $^ -o $@ $(ARGS )

$(OBJ)/%.o:$(SRC)/%.c
        gcc -c $< -o $@ $(ARGS) -I $(inc_path)


clean:
        -rm -rf $(obj) a.out 
        #“-”:作用是,删除不存在文件时,不报错。顺序执行

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值