C语言 makefile学习及实现实例 俗话说,不会写makefile的程序员不是好的程序员。 看了很多人写的makefile教程,感觉太难懂,还不如韦东山老师视频里讲的好理解。 先记下这几个符号,以
C语言 makefile学习及实现实例
俗话说,不会写makefile的程序员不是好的程序员。
看了很多人写的makefile教程,感觉太难懂,还不如韦东山老师视频里讲的好理解。
先记下这几个符号,以后看到就不会忘记这是什么东西了。
先来看一个例子:
<span style="font-size:18px;">Person: main.o person.o g++ -o $@ $^ %.o : %.cpp g++ -c -o $@ $< clean: rm -rf *.o Person</span>
其中:
1、Person表示要生成的目标文件。
main.o person.o是依赖文件
所以Person: main.o person.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:
对应下面的文件,如果你执行make clean,makefile就会帮你清除所有的.o和Person这个目标文件。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!