makefile--自动化编译

源文件首先会生成中间目标文件,再由中间目标文件生成执行文件。在编译时,编译器只检测程序语法,和函数、变量是否被声明。如果函数未被声明,编译器会给出一个警告,但可以生成Object File。而在链接程序时,链接器会在所有的Object File中找寻函数的实现,如果找不到,那到就会报链接错误码(Linker Error),在VC下,这种错误一般是:Link 2001错误,意思说是说,链接器未能找到函数的实现。你需要指定函数的Object File.

一、规则

目标文件 ... : 依赖文件 ... 
            make需要执行的命令

目标文件:多个以空格分开,可以使用通配符。可以是Object File、执行文件、标签(Label)。

* 命令:与依赖文件同行可以用分号做为分隔;下行必须要以[Tab]键开始。

* 一个或多个的目标文件依赖于依赖文件中的文件,其生成规则定义在命令中。依赖文件中如有一个以上的文件比目标文件要新的话,命令会被执行。

二、Makefile里主要元素:

1、显式规则。

2、隐晦规则。由make有自动推导的功能 

3、变量的定义。

4、文件指示。

5、注释。“#”字符

三、文件搜寻

make会在当前的目录中去找寻依赖文件和目标文件。如果定义“VPATH”,那么,make就会在当前目录找不到的情况下,到所指定的目录中去找寻文件。 

    VPATH = 目录由“冒号”分隔 

make的“vpath”关键字更为灵活。它可以指定不同的文件在不同的搜索目录中。使用方法有三种: 

    1、vpath 为符合模式;的文件指定搜索目录;。 

    2、vpath 清除符合模式;的文件的搜索目录。 

    3、vpath 清除所有已被设置好了的文件搜索目录。 

四、多目标

“$@”表示目标的集合,就像一个数组,“$@”依次取出目标,并执于命令。

$< 


五、autoconfig

能生成用于自动配置源代码的 shell 脚本。


参考

http://www.cnblogs.com/yyangblog/p/4159778.html

你可能感兴趣的:(makefile--自动化编译)