makefile文件编写简单入门示例

Linux编程初学者一般对一个含多个文件的项目的编译执行过程感到苦恼,如果每一次执行,都要先对每一个源文件都一条条的编译,那简直是一场灾难。学会了makefile文件的编写,就能很轻松的解决这个问题了。

现在我们来看一个简单的程序,一共包含三个文件:

1. print.h
      #include
      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就这样写好了,简单吧!

makefile文件编写简单入门示例_第1张图片


你可能感兴趣的:(Linux)