Makefile笔记

1.所有要执行的系统命令都是使用tab符号开始的。其他不过是辅助。

2.定义变量
wildcard:产生所有以.c/.cpp结尾的文件的列表,这个列表也是“一个变量”,所以需要使用 ()patsubst:param1:;param2:;param3:param3param1使parm2: ()来使用。

3.$<表示第一个依赖文件,它同$@, $^都是makefile提供的自动变量。
<:file1.ofile1.c/file1.cpp, <script type="math/tex" id="MathJax-Element-79"><: 表示第一个依赖文件,如编译file1.o那么它的第一个依赖文件就是file1.c/file1.cpp,具体是由编译器自动推导的 </script>@: 表示目标文件,编译器会自动将这个变量扩展为当前规则的目标文件名
$^: 表示所有依赖文件,编译器会自动将这个变量扩展为当前规则所有依赖的文件(除去所有重复的文件名)

%.o:%.c/%.cpp 表示将所有的.c/.cpp文件都编译成成对应的.o文件。

4.目标all只有依赖没有具体的系统命令。这相当有是make的入口,make在编译的时候是这样执行的:当遇到一个目标的时候
就查询它的所有依赖文件,如果某个依赖文件不存在,那么就去找寻是否有生成改依赖文件的代码,有就执行,否则报错;
注意这个过程是递归进行的~~all就相当于告诉编译器,我们最终要生成的文件是什么,然后编译器就依次去执行命令直到生成这个文件
或发生错误为止

SOURCE=$(wildcard *.c *.cpp)
OBJS=$(patsubst %.c, %.o, $(patsubst %.cpp, %.o, $(SOURCE)))
CC=gcc
XX=g++
CFLAGS=-Wall -O -g  
TARGET=manifestAmbiguity

all: $(TARGET)  

%.o:%.c
    $(CC) $(CFLAGS) -c $< -o $@

%.o:%.cpp
    $(XX) $(CFLAGS) -c $< -o $@

$(TARGET): $(OBJS)
    $(CC) $(CFLAGS) $(OBJS) -o $(TARGET)


clean:
    rm -rf *.o manifestAmbiguity
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值