C语言 makefile学习及实现实例
C语言makefile学习及实现实例
俗话说,不会写makefile的程序员不是好的程序员。
看了很多人写的makefile教程,感觉太难懂,还不如韦东山老师视频里讲的好理解。
先记下这几个符号,以后看到就不会忘记这是什么东西了。
先来看一个例子:
Person:main.operson.o g++-o$@$^ %.o:%.cpp g++-c-o$@$< clean: rm-rf*.oPerson
其中:
1、Person表示要生成的目标文件。
main.o person.o是依赖文件
所以Person:main.operson.o
这句话的意思就是,要想生成Person这个文件,就要依赖于main.o,person.o这两个文件。
2、$@:表示目标文件,这里的目标文件就是Person
$^ : 表示目标文件后面的所有依赖文件,也就是.o文件
$< : 表示第一个依赖文件,这里的第一个指的就是main.o
3、%.o:%.cpp
%,o:%,cpp前面加%表示通配符,表示通配所有的.o文件还有所有的.cpp文件
4、还有一点要注意,上面g++前面不是空格,而是一个tab,一般情况下,tab是4个空格的大小。
5、clean:
对应下面的文件,如果你执行makeclean,makefile就会帮你清除所有的.o和Person这个目标文件。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!