简单makefile实例
1,源文件:
main.cpp
#include <stdio.h>
int main()
{
printf("Hello World\n");
return 0;
}
2,编写makefile
若使用g++命令编译链接程序,可以:
g++ -o hello main.cpp
或
g++ [-o main.o] -c main.cpp
g++ -o hello main.o
若使用make命令,则可以这么编写makefile文件(两种写法分别对应了上面说的两条g++命令):
提示:
2.1,makefile的基本格式为“目标:依赖 命令”
一个 makefile 主要含有一系列的规则,如下:
A: B
(tab)<command>
(tab)<command>
重要: 每个命令行前都必须有tab符号
举例来说,一种简单写法如下:
main : main.c
gcc main.c –o main
在终端执行make命令就可以得到main文件了
2.2 执行过程
通常make命令会逐行解释makefile文件,然后执行第一个”目标格式行”及其后的”目标命令行“。直到碰到下一个”目标格式行”为止。
注意这里指的是下一个”目标格式行“,而不是文件末尾。
所以我们把生成最后的可执行文件的makefile代码放在第一行时,只需要键入make就可以。
而有些makefile文件未将生成最后的可执行文件的代码放在第一行,所以如果make的话,就只能执行到第一个目标格式行的code.
另外,我们使用伪目标让makefile执行不同的操作,如定制Debug和Release版本,清空中间生成文件,安装软件包等等。
2.3, 这里要说明一点的是,clean不是一个文件,它只不过是一个动作名字,其冒号后面为空,make就不会找文件的依赖性,也就不会自动执行其后所定义的命令。
要执行其后的命令,就需要在make 命令后显式指出这个名字。这样我们就可以定义一些与编译无关的命令:打包程序,清理程序等外围操作等。
用".PHONY {目标名}"定义一个伪目标, 用"make {目标名}"执行该伪目标
.PHONY : clean
clean :
@rm -f main *.o
@echo 'clean'
此时执行make命令,终端会显示系统执行的每条命令,如果你不想系统显示它执行的命令,在每条命令的前面加上“@”即可。
hello : main.cpp
g++ main.cpp -o hello
clean:
rm hello main.o -rf
或
hello: main.o
g++ -o hello main.o
main.o : main.cpp
g++ -c main.cpp
clean:
rm hello main.o -rf
3,执行make,进行编译链接,
[root@localhost 0-helloworld]#make
g++ -o hello main.o
[root@localhost 0-helloworld]#ll
总用量 20
-rwxr-xr-x 1 root root 6908 11月 26 22:59 hello
-rw-r--r-- 1 root root 72 11月 26 22:10 main.cpp
-rw-r--r-- 1 root root 1472 11月 26 22:35 main.o
-rw-r--r-- 1 root root 144 11月 26 22:51 makefile
4,执行程序
[root@localhost 0-helloworld]#./hello
Hello World
5,清理程序
[root@localhost 0-helloworld]#make clean
rm hello main.o -rf
[root@localhost 0-helloworld]#ll
总用量 8
-rw-r--r-- 1 root root 72 11月 26 22:10 main.cpp
-rw-r--r-- 1 root root 151 11月 26 23:02 makefile
[root@localhost 0-helloworld]#