Makefile(example)

A Simple Makefile Example

val = A.o B.o

def_file := $(patsubst %,.%.d,$(val))
out: $(val)
	gcc -o out $^
%.o:%.c
	gcc -c -o $@ $<	-MD -MF .$@.d
clean:
	@$(val) $(def_file)
.PHONY:clean

简单的例子。当想编译A.c和B.c文件,以及他们的头文件时。
先定义一个变量val,使其为所需.o文件,然后用到

gcc -MD -MF filename

命令,查找.c文件的依赖关系即头文件所在位置且将其写入filename中,然后编译。
还使用了

$(patsubst %,.%.d,$(val))

函数将val中的.o文件变成.name.d文件,即用来存储头文件所在位置的文件。

$^:目标所有的依赖文件,例子中指A.o,B.o
$@:所有的目标文件,例子中分别指A.o,B.o
$<:第一个依赖文件,例子中先指A.c,再指B.c

这个例子适用于少数.c文件的情况下,且只需更改val变量即可。最终目标文件依照个人情况可酌情更改。学习期间,应该够用了。
1


  1. 个人学习情况的一个总结,还是小白,应该还有些理解不对的地方。 ↩︎

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值