Linux编程初学者一般对一个含多个文件的项目的编译执行过程感到苦恼,如果每一次执行,都要先对每一个源文件都一条条的编译,那简直是一场灾难。学会了makefile文件的编写,就能很轻松的解决这个问题了。
现在我们来看一个简单的程序,一共包含三个文件:
1. print.h
#include<stdio.h>
void print_Hello();
2. print.c
#include"print.h"
void print_Hello(){
printf("Hello, world\n");
}
3. main.c
#include "print.h"
int main(void){
print_Hello();
return 0;
}
//为每一个.c文件生成.o文件
gcc -o print print.c
gcc -o main main.c
//连接每一个*o文件,生成可执行文件。
gcc -o helloworld main.o print.o
现在我们该用makefile文件来实现以上过程:
首先,在与源文件同一文件夹下新建一个文件名为“Mikefile”的文件,不要后缀名。
然后,添加如下代码:
helloworld : main.o print.o//helloword 就是我们要生成的目标
gcc -o helloworld main.o print.o //注意凡是包含gcc等shell命令的代码,在该行前面一定要以tab键开头
mian.o : mian.c print.h
print.o: print.c print.h
clean://这条命令用来清除所有的.o文件
rm *.o //该行同样要以tab键开头
好了,到此为止,一个makefile文件就写好了!
在文件所在的目录下,输入 “make” 命令,所有的编译链接过程就全部完成了!
如有要清除所有生成的.o文件,运行 "make clean" 命令即可。
上面所讲的例子只要链接两个.o文件,如果有几十个怎么办呢?我们可以将所有的.o文件定义为一个变量。
于是,改进的makefile文件如下:
objects = main.o print.o
helloworld : $(objects) //这句等价于上面的第一句
gcc -o helloworld $(objects)
$(objects) : print.h //两个.o文件的编译都用到了print.h
mian.o : mian.c
print.o : print.c
clean:
rm *.o
好了,一个更加简洁的makefile就这样写好了,简单吧!