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这个目标文件。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:Makefile/cmake/node-gyp中区分判断不同平台的方法linux 驱动之Kconfig文件和Makefile文件实例Linux里Makefile是什么?它是如何工作的?Linux 中makefile的命令包定义及使用Linux makefile 和shell文件相互调用实例详解关于Linux下对于makefile的理解Python实现生成简单的Makefile文件代码示例Linux/Unix环境下的Make和Makefile详解Linux下Makefile的automake生成全攻略C++关于Makefile的详解含通用模板