日期:2014-05-16  浏览次数:20747 次

Linux下C多文件编译Makefile

第一:Makefile文件编写|
    1.第一个字母大写,其余的都是小写。|
    2.Makefile关系到了整个工程的编译。|
    3.可以执行操作系统的命令。|
    4.其实Makefile的本质是定义了文件之间的依赖性问题。|
    5.第一个字母大写,其余的都是小写。|

make命令执行时,需要一个 Makefile 文件,以告诉make命令需要怎么样的去编译和链接程序。

第二:   例子
    1.我们使用gcc来编译多个源文件时,使用执行多条命令,但是使用make命令就不一
      样了,见下面
    2.编写Makefile文件
      main:one.o two.o three.o 
 
         gcc one.o two.o three.o –o main 
      one.o:one.c 
          gcc -c one.c  
      two.o:two.c 
          gcc -c two.c  
 
      three.o:three.c 
          gcc -c three.c
      clean:
            rm one.o two.o three.o //使用make clean 删除中间文件
     
第三:总结
    总结一下Makefile的规则:
    [c-sharp] view plaincopy
     target ... : prerequisites ...   
            command  
            ... 
            ... 
    target也就是一个目标文件,可以是Object File,也可以是执行文件。还可以是
    一个标签(Label)。
    prerequisites就是要生成那个target所需要的文件或是目标。
    command也就是make需要执行的命令。(任意的Shell命令)
    这是一个文件的依赖关系,也就是说,target这一个或多个的目标文件依赖于
    prerequisites中的文件,其生成规则定义在command中。说白一点就是说,   
    prerequisites中如果有一个以上的文件比target文件要新的话,command所定
    义的命令就会被执行。这就是Makefile的规则。也就是Makefile中最核心的内容。

第四:make命令工作过程总结
   1、make会在当前目录下找名字叫“Makefile”的文件。
   2、如果找到,它会找文件中的第一个目标文件(target),并把这个文件作为最
      终的目标文件。像上面的例子为file
   3、如果file文件不存在,或是file所依赖的后面的 .o 文件的文件修改时间要比
      file这个文件新,那么,他就会执行后面所定义的命令来生成file这个文件。
   4、如果file所依赖的.o文件也不存在,那么make会在当前文件中找目标为.o文件
      的依赖性,如果找到则再根据那一个规则生成.o文件。
   5、当然,你的C文件和H文件是存在的啦,于是make会生成 .o 文件,然后再用 .o
      文件生命make的终极任务,也就是执行文件file了。