makefile笔记4 - makefile命令】的更多相关文章

一.makefile的组成 Makefile 里主要包含了五个东西:显示规则.隐晦规则.变量定义.文件指示和注释. 1. 显示规则.显示规则说明了,如何生成一个或多的的目标文件.这是由 Makefile 的书写者明显指出,包括①生成的文件,②文件的依赖文件,③生成的命令.在 Makefile 中的命令,必须要以[Tab]键开始.规则其实就是上一讲中的 target ... : prerequisites ... command ... ... 2. 隐晦规则.由于我们的 make 有自动推导的功…
每条规则中的命令和操作系统 Shell 的命令行是一致的. make 会一按顺序一条一条的执行命令,每条命令的开头必须以[Tab]键开头,除非,命令是紧跟在依赖规则后面的分号后的. 在命令行之间中的空格或是空行会被忽略,但是如果该空格或空行是以 Tab 键开头的,那么make 会认为其是一个空命令. 我们在 UNIX 下可能会使用不同的 Shell,但是 make 的命令默认是被"/bin/sh"--UNIX的标准 Shell 解释执行的.除非你特别指定一个其它的 Shell. Mak…
在我们使用 Makefile 时,有一些我们会经常使用,而且使用频率非常高的东西,比如,我们编译C/C++的源程序为中间目标文件(Unix 下是[.o]文件,Windows 下是[.obj]文件). 本章讲述的就是一些在 Makefile 中的"隐含的",早先约定了的,不需要我们再写出来的规则. "隐含规则"也就是一种惯例, make 会按照这种"惯例"心照不喧地来运行,那怕我们的Makefile 中没有书写这样的规则.例如,把[.c]文件编译成…
函数库文件也就是对 Object 文件(程序编译的中间文件)的打包文件.在 Unix 下,一般是由命令"ar"来完成打包工作. 一.函数库文件的成员 一个函数库文件由多个文件组成.你可以以如下格式指定函数库文件及其组成: archive(member) 这个不是一个命令,而一个目标和依赖的定义.一般来说,这种用法基本上就是为了"ar"命令来服务的.如: foolib(hack.o) : hack.o ar cr foolib hack.o 如果要指定多个 membe…
在 Makefile 中可以使用函数来处理变量,从而让我们的命令或是规则更为的灵活和具有智能. make 所支持的函数也不算很多,不过已经足够我们的操作了.函数调用后,函数的返回值可以当做变量来使用. 一.函数的调用语法 函数调用,很像变量的使用,也是以"\(\$\)"来标识的,其语法如下: $(<function> <arguments>) 或是 ${<function> <arguments>} 这里, <function>…
使用条件判断,可以让 make 根据运行时的不同情况选择不同的执行分支.条件表达式可以是比较变量的值,或是变量和常量的值. 一.示例 下面的例子,判断\(\$\)(CC)变量是否"gcc",如果是的话,则使用 GNU 函数编译目标. libs_for_gcc = -lgnu normal_libs = foo: $(objects) ifeq ($(CC),gcc) $(CC) -o foo $(objects) $(libs_for_gcc) else $(CC) -o foo $(…
在 Makefile 中的定义的变量,就像是 C/C++语言中的宏一样,他代表了一个文本字串,在 Makefile 中执行的时候其会自动原模原样地展开在所使用的地方.其与 C/C++所不同的是,你可以在 Makefile 中改变其值.在 Makefile 中,变量可以使用在"目标","依赖目标","命令"或是 Makefile 的其它变量中. 变量的命名字可以包含字符.数字,下划线(可以是数字开头),但不应该含有":".&qu…
target ... : prerequisites ... command ... ... 规则包含两个部分,一个是依赖关系,一个是生成目标的方法. 在 Makefile 中,规则的顺序是很重要的,因为, Makefile 中只应该有一个最终目标,其它的目标都是被这个目标所连带出来的,所以一定要让 make 知道你的最终目标是什么.一般来说,定义在 Makefile 中的目标可能会有很多,但是第一条规则中的目标将被确立为最终的目标.如果第一条规则中的目标有很多个,那么,第一个目标会成为最终的目…
使用gcc编译C语言源码 在Linux系统中,C语言源码需要用gcc编译为二进制可执行文件,才能够运行. $ gcc test.c -o test 这句命令就将test.c文件编译为test二进制可执行文件. $ ./test 如此可以直接执行编译后的test二进制可执行文件. 如何编译多个.c文件 例1 需要将test1.c.test2.c.test3.c合并编译为一个test可执行文件. 一种办法是: $ gcc test1.c test2.c test3.c -o test 这个办法的缺陷…
一般来说,最简单的就是直接在命令行下输入 make 命令, make 命令会找当前目录的makefile 来执行,一切都是自动的.但也有时你也许只想让 make 重编译某些文件,而不是整个工程,而又有的时候你有几套编译规则,你想在不同的时候使用不同的编译规则,等等.本章节就是讲述如何使用 make 命令的. 一. make 的退出码 make 命令执行后有三个退出码: 0 -- 表示成功执行. 1 -- 如果 make 运行时出现任何错误,其返回 1. 2 -- 如果你使用了 make 的"-q…