Makefile笔记

来源:互联网 发布:收藏加购软件 编辑:程序博客网 时间:2024/06/06 12:54

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

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

3.$<表示第一个依赖文件,它同$@, $^都是makefile提供的自动变量。
<:file1.ofile1.c/file1.cpp,@: 表示目标文件,编译器会自动将这个变量扩展为当前规则的目标文件名
$^: 表示所有依赖文件,编译器会自动将这个变量扩展为当前规则所有依赖的文件(除去所有重复的文件名)

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

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

SOURCE=$(wildcard *.c *.cpp)OBJS=$(patsubst %.c, %.o, $(patsubst %.cpp, %.o, $(SOURCE)))CC=gccXX=g++CFLAGS=-Wall -O -g  TARGET=manifestAmbiguityall: $(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
原创粉丝点击