make与makefile
一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。VS中已经自动化处理,而Linux下需要自己处理维护。
makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。
make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。
make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。
依赖关系、依赖方法
makefile的简单编写
$@
:目标文件$^
:源文件列表- 结合起来等于:
gcc t1.c tf1.c -o t1.exe
.PHONY:
:伪目标声明
CC=g++
LDFLAGS=-std=c++11
Src=t1.cc
Bin=blockqueuet1
$(Bin):$(Src)
$(CC) -o $@ $^ $(LDFLAGS) -lpthread
.PHONY:clean
clean:
rm $(Bin)
make原理
- make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
项目清理
- 工程是需要被清理的,就像vs中的清理生成解决方案
- 像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行。即命令——
make clean
,以此来清除所有的目标文件,以便重编译。 - 但是一般我们这种clean的目标文件,我们将它设置为伪目标,用
.PHONY
修饰,伪目标的特性是,总是被执行的。- 假如:
- 假如:
待参考…
本文含有隐藏内容,请 开通VIP 后查看