×

makefile注释符号

makefile注释符号(makefile 文件详细介绍)

admin admin 发表于2023-10-04 18:14:50 浏览37 评论0

抢沙发发表评论

本文目录

makefile 文件详细介绍

makefile文件主要有以下五种组成部分。显式规则:显式规则说明了生成一个或多个目标文件的方法和步骤。这是在编写makefile文件时明显指出的,包括要生成的文件、生成文件的依赖文件以及生成的命令等。隐式规则:由于make工具有自动推导的功能,所以在编写makefile文件的时候可以利用该规则,简略地书写makefile。再由 make 工具本身自动推导需要使用的规则。变量的定义: make工具支持变量的定义,这些变量往往都是字符串,因此makefile中的变量更像是C语言中的宏。当makefile被执行时,其中的变量都会被展开到相应的引用位置上。文件指示:其包括三个部分,一个是在一个makefile中引用另一个makefile,就像C语言中的include一样。另一个是指根据某些情况指定makefile中的有效部分,就像C语言中的预编译tlif一样。还有就是定义一个多行的命令。注释: makefile 中支持行注释,这一点需要特别注意。makefile 中的注释和 shell脚本一样,其注释是用“#”字符。如果需要在 makefile中使用“#”字符,可以用‘\’对其进行转义。例如,“\#”表示一个‘#’字符。makefile文件的文件名最好命名为makefile或者Makefile。因为在默认的情况下,make命令会在当前目录下按顺序找寻这两个文件进行解释。用户也可以为makefile文件自定义一个文件名,例如,Make.makefile,Make.admin等。

makefile由什么组成

makefile文件主要有以下五种组成部分。显式规则:显式规则说明了生成一个或多个目标文件的方法和步骤。这是在编写makefile文件时明显指出的,包括要生成的文件、生成文件的依赖文件以及生成的命令等。隐式规则:由于make工具有自动推导的功能,所以在编写makefile文件的时候可以利用该规则,简略地书写makefile。再由 make 工具本身自动推导需要使用的规则。变量的定义: make工具支持变量的定义,这些变量往往都是字符串,因此makefile中的变量更像是C语言中的宏。当makefile被执行时,其中的变量都会被展开到相应的引用位置上。文件指示:其包括三个部分,一个是在一个makefile中引用另一个makefile,就像C语言中的include一样。另一个是指根据某些情况指定makefile中的有效部分,就像C语言中的预编译tlif一样。还有就是定义一个多行的命令。注释: makefile 中支持行注释,这一点需要特别注意。makefile 中的注释和 shell脚本一样,其注释是用“#”字符。如果需要在 makefile中使用“#”字符,可以用‘\’对其进行转义。例如,“\#”表示一个‘#’字符。makefile文件的文件名最好命名为makefile或者Makefile。因为在默认的情况下,make命令会在当前目录下按顺序找寻这两个文件进行解释。用户也可以为makefile文件自定义一个文件名,例如,Make.makefile,Make.admin等。

linux Makefile configure里面 += := -= 这些符号的意思

‘=’定义的叫递归展开式变量,用它给某个变量赋值,后面的表达式不会在定义时就展开,而是在make程序执行到他的相关操作的时候才展开——即用的时候才生效‘:=’定义的叫直接展开式变量,赋值时将后面表达式的值马上展开传递给变量——即立即生效。+=,-=这种是用来对变量进行追加定义的操作符,在原有的定义基础上加上或减去某个定义,比如去掉某个对象.o文件。

makefile文件组成

makefile文件主要有以下五种组成部分。显式规则:显式规则说明了生成一个或多个目标文件的方法和步骤。这是在编写makefile文件时明显指出的,包括要生成的文件、生成文件的依赖文件以及生成的命令等。隐式规则:由于make工具有自动推导的功能,所以在编写makefile文件的时候可以利用该规则,简略地书写makefile。再由 make 工具本身自动推导需要使用的规则。变量的定义: make工具支持变量的定义,这些变量往往都是字符串,因此makefile中的变量更像是C语言中的宏。当makefile被执行时,其中的变量都会被展开到相应的引用位置上。文件指示:其包括三个部分,一个是在一个makefile中引用另一个makefile,就像C语言中的include一样。另一个是指根据某些情况指定makefile中的有效部分,就像C语言中的预编译tlif一样。还有就是定义一个多行的命令。注释: makefile 中支持行注释,这一点需要特别注意。makefile 中的注释和 shell脚本一样,其注释是用“#”字符。如果需要在 makefile中使用“#”字符,可以用‘\’对其进行转义。例如,“\#”表示一个‘#’字符。makefile文件的文件名最好命名为makefile或者Makefile。因为在默认的情况下,make命令会在当前目录下按顺序找寻这两个文件进行解释。用户也可以为makefile文件自定义一个文件名,例如,Make.makefile,Make.admin等。

linux Makefile configure里面 += := -= 这些符号的意思

:=和=用在赋值时,:=的赋值是马上生效,而=则是等到变量被引用时才递归生效。用两个简单的makefile举例说明最简单:makefile1:bar=456foo=${bar}bar=${xxx}xxx=123all:echo${foo}echo出的结果是123,foo的值在echo的时候,先被扩展成${bar},再递归的被扩展成${xxx},最终是123makefile2:bar=456foo:=${bar}bar=${xxx}xxx=123all:echo${foo}此时由于用了:=,在赋值时候foo的值就直接被扩展成bar在那个时刻的值,即456,最后的echo的结果也就是456了。+=就很简单了,就是在一个变量的值的尾部增加内容,如:foo=abcfoo+=efg则foo的值就是abcefgmakefile没有-=这个操作符。

makefile 文件介绍

makefile文件主要有以下五种组成部分。显式规则:显式规则说明了生成一个或多个目标文件的方法和步骤。这是在编写makefile文件时明显指出的,包括要生成的文件、生成文件的依赖文件以及生成的命令等。隐式规则:由于make工具有自动推导的功能,所以在编写makefile文件的时候可以利用该规则,简略地书写makefile。再由 make 工具本身自动推导需要使用的规则。变量的定义: make工具支持变量的定义,这些变量往往都是字符串,因此makefile中的变量更像是C语言中的宏。当makefile被执行时,其中的变量都会被展开到相应的引用位置上。文件指示:其包括三个部分,一个是在一个makefile中引用另一个makefile,就像C语言中的include一样。另一个是指根据某些情况指定makefile中的有效部分,就像C语言中的预编译tlif一样。还有就是定义一个多行的命令。注释: makefile 中支持行注释,这一点需要特别注意。makefile 中的注释和 shell脚本一样,其注释是用“#”字符。如果需要在 makefile中使用“#”字符,可以用‘\’对其进行转义。例如,“\#”表示一个‘#’字符。makefile文件的文件名最好命名为makefile或者Makefile。因为在默认的情况下,make命令会在当前目录下按顺序找寻这两个文件进行解释。用户也可以为makefile文件自定义一个文件名,例如,Make.makefile,Make.admin等。

给下列makefile文件作注释

(1-6) : INCLUDES 后面定义的是头文件搜索的目录列表,-I后面好像不用空格(7-11) : 以上是对宏的定义,,以-D开头,其效果与文件中的#define等效,与#define不同之处在于其定义的宏是全局的,而#define定义的宏只在一个文件中有效。(11-15) : 编译参数CFLAGS定义,+=的意思是在以前的基础上再加上现有的值。按照上面的意义最后CFLAGS应该是 - O -g -DMODEL= tune1 -DRT -DNUMST=2 -DTID01EQ = 1 -DNCSTATES = 0 -DMT = 0 -DHAVESTDIO -DEXT_MODE -DUSE_RTMODEL16-17: 源文件定义18 :目标文件是将源文件的.c换成.o,即如果SRCS件中有 tune1.c 则SRCS就会有tune1.o.19: RM工具定义20:编译器定义21 链接器定义(这里应该写错了或者需要对链接参数做特殊的定义才能也将LD定义成gcc)22.目标定义23.所有的.o文件都对与其同名的.c文件进行编译24 $(CC)代表gcc,-c代表只编译,-o表示输出的文件 $@代表目标文件(-o $@在这里代表被编译的.o) CFLAGS 和 INCLUDES 一个是编译选项一个是头文件目录 $《 指的是 %.c25-26.如果 $(OBJS)都存在,则声称tunel,其实就是链接,-lm 只的是链接以一个libm.a库文件27-28 移除文件综上,如果make clean 则会清除所有.o文件 make tunrl 或者 make all 都会生成tune1

makefile 文件的组成内容

makefile文件主要有以下五种组成部分。显式规则:显式规则说明了生成一个或多个目标文件的方法和步骤。这是在编写makefile文件时明显指出的,包括要生成的文件、生成文件的依赖文件以及生成的命令等。隐式规则:由于make工具有自动推导的功能,所以在编写makefile文件的时候可以利用该规则,简略地书写makefile。再由 make 工具本身自动推导需要使用的规则。变量的定义: make工具支持变量的定义,这些变量往往都是字符串,因此makefile中的变量更像是C语言中的宏。当makefile被执行时,其中的变量都会被展开到相应的引用位置上。文件指示:其包括三个部分,一个是在一个makefile中引用另一个makefile,就像C语言中的include一样。另一个是指根据某些情况指定makefile中的有效部分,就像C语言中的预编译tlif一样。还有就是定义一个多行的命令。注释: makefile 中支持行注释,这一点需要特别注意。makefile 中的注释和 shell脚本一样,其注释是用“#”字符。如果需要在 makefile中使用“#”字符,可以用‘\’对其进行转义。例如,“\#”表示一个‘#’字符。makefile文件的文件名最好命名为makefile或者Makefile。因为在默认的情况下,make命令会在当前目录下按顺序找寻这两个文件进行解释。用户也可以为makefile文件自定义一个文件名,例如,Make.makefile,Make.admin等。

[Linux]编写一个简单的C语言程序,编写Makefile文件

八 环境变量 8.1 查看环境变量 $ env  显示所有的环境变量设置 $ echo $ENV_VARIABLE  显示指定环境变量的设置 例: $ echo $PATH /bin:/etc:/usr/bin:/tcb/bin 8.2 设定环境变量 $ ENV_VARIABLE=XXX;export ENV_VARIABLE 例: $ PATH=$PATH:$INFORMIXDIR/bin;export PATH  将环境变量PATH设定为原PATH值+$INFORMIXDIR/bin 8.3 取消环境变量设置 $ unset $ENV_VARIABLE 例: $ set GZJ=gzj;export GZJ  设置环境变量GZJ $ echo $GZJ gzj  显示环境变量值 $ unset $GZJ  取消环境变量GZJ的设置 $ echo $GZJ  已取消 一 makefile规则 makefile是一个make的规则描述脚本文件,包括四种类型行:目标行、命令行、宏定义行和make伪指令行(如“include”)。makefile文件中注释以“#”开头。当一行写不下时,可以用续行符“\”转入下一行。 1.1 目标行 目标行告诉make建立什么。它由一个目标名表后面跟冒号“:”,再跟一个依赖性表组成。 例: example: depfile deptarget 该目标行指出目标example与depfile和deptarget有依赖关系,如果depfile或deptarget有修改,则重新生成目标。 example1 example2 example3: deptarget1 deptarget2 depfile 该目标行指出目标名表中的example1、example2、example3这三个各自独立的目标是用相同的依赖列表和规则生成的。 clean: 空的依赖列表说明目标clean没有其他依赖关系。 目标行后续的以Tab 开始的行是指出目标的生成规则,该Tab字符不能以空格代替。例如: example.o:example.c example.h cc –c example.c 该例子指出目标example.o依赖于example.c和example.h。如果example.c或example.h其中之一改变了,就需要执行命令cc –c example.c重新生成目标example.o。 可以用文件名模式匹配来自动为目标生成依赖表,如: prog: *.c 以下是一个简单的makefile的例子: 图 1 最简单的makefile例 make使用makefile文件时,从第一个目标开始扫描。上例中的第一个目标为all,所以目标clean不会自动被执行,可以通过命令make clean来生成目标。 1.2 命令行 命令行用来定义生成目标的动作。 在目标行中分号“;”后面的文件都认为是一个命令,或者一行以Tab制表符开始的也是命令。 如在上面的makefile例中,第三行以Tab字符开始的cc命令即是一个命令行,说明要生成hello应执行的命令。也可以写成:hello:hello.o;cc –c hello –L… 一般情况下,命令行的命令会在标准输出中回显出来,如对上面的makefile执行make时,标准输出如下: cc -c hello.c cc -o hello -L/usr/X11R6/lib -L/usr/lib -lXm -lXt -lX11 hello.o cc -c hello1.c cc -o hello1 -L/usr/X11R6/lib -L/usr/lib -lXm -lXt -lX11 hello1.o 如果不希望命令本身回显,可在命令前加@字符,如在上例中不希望回显cc –c hello.c和cc –c hello1.c,可修改makefile文件如下: 图 2 抑制回显的makefile例 对该makefile文件执行make时,标准输出如下: cc -o hello -L/usr/X11R6/lib -L/usr/lib -lXm -lXt -lX11 hello.o cc -o hello1 -L/usr/X11R6/lib -L/usr/lib -lXm -lXt -lX11 hello1.o 可以看出,命令行前有@字符的不回显。 1.3 宏定义行 在makefile中,可以使用宏定义减少用户的输入,例如上例中对hello和hello1的编译选项均为“-L/usr/X11R6/lib -L/usr/lib -lXm -lXt -lX11”,此时可以用宏来代替,如: 图 3 使用宏定义的makefile例 宏定义的基本语法是: name=value 在定义宏时,次序不重要。宏不需要在使用前定义。如果一个宏定义多次,则使用最后一次的定义值。 可以使用“$”字符和“()”或“{}”来引用宏,例如: cc –o hello.o $(CCFLAGS) hello.o 也可以将一个宏赋值给另一个宏,但这样的定义不能循环嵌套,如: A=value1 B=value2 C=$(A) $(B)等价于C=value1 value2 1.4 伪指令 makefile大部分由宏定义行、命令行和目标行组成。第四种类型是make伪指令行。make伪指令没有标准化,不同的make可能支持不同的伪指令集,使得makefile有一定的不兼容性。如果要考虑移植性问题,则要避免使用make伪指令。但有一些伪指令,如include,由于使用比较多,很多不同make都提供该伪指令。 1.4.1 伪指令include 该伪指令类似C语言中的#include,它允许一次编写常用的定义并包括它。include伪指令必须在一行中,第一个元素必须是include,并且跟一个要包含的文件名,如: include default.mk 1.4.2 伪指令“#” “#”字符也是make的伪指令,它指出“#”后面的文件是注释,如: PROGNAME=test # define macro #don’t modify this 二 后缀规则 2.1 双后缀规则 在前面的makefile例中有许多重复内容,例如,生成hello和hello1的命令类似,生成hello.o和hello1.o的命令也类似,除了编译或链接的文件不一样外,其它均相同,这时,我们就可以使用后缀规则。首先看一个双后缀的例子: 图 4 使用双后缀规则的makefile例 后缀规则使用特殊的目标名“.SUFFIXES”。 第一行中.SUFFIXES的依赖表为空,用来清除原有的后缀规则,因为.SUFFIXES可以在makefile中多次使用,每一次都将新的后缀规则加入以前的后缀规则中。 第二行中指定后缀规则为“.c .o”,即表示将所有的.c文件转换为.o文件。 第三行指定将.c文件转换成.o文件的方法。$(CC)为make的预定义宏,其默认值为cc,$《为特殊的宏,代替当前的源文件,即所有要编译的.c文件。 第六行指定目标hello和hello1的生成方法。$@为特殊的宏,代替当前的目标名,即hello和hello1,$@.o即为hello.o和hello1.o。 上例介绍的是双后缀规则,即它包含两个后缀,如.c.o,用来把一个C源文件编译为目标文件。双后缀规则描述如何由第一个后缀类型的文件生成第二个后缀类型的文件,例如:.c.o规则描述如何由.c文件生成.o文件。 2.2 单后缀规则 单后缀规则描述了怎样由指定后缀的文件生成由它基名为名字的文件。例如使用单后缀规则.c,可以由hello.c和hello1.c生成hello和hello1文件。例如将前面的makefile改为: 图 5 使用单后缀规则的makefile例 由于.c后缀规则为make标准后缀规则,make为其指定了相应的命令行,所以在makefile中可以不用再指定其目标生成的具体命令行。 下表是make提供的标准后缀规则。 表 1 make标准后缀规则 后缀规则 命令行 .c $(LINK.c) –o $@ $《 $(LDLIBS) .c.ln $(LINK.c) $(POUTPUT OPTPUT OPTION) –i $《 .c.o $(COMPILE.c) $(OUTPUT OPTION) $《 .c.a $(COMPILE.c) –o $% $《 $(AR) $(ARFLAGS) $@ $% $(RM) $% 三 特殊目标 在后缀规则中使用了特殊目标.SUFFIXES,用来指定新增的后缀规则。make还提供了几个特殊目标来设置make的行为,下面为一些特殊的目标:  .IGNORE make在执行命令行时,如果返回的是错误码,make的缺省动作是停止并退出。增加该目标后,make将忽略命令行返回的错误码,并继续执行后续的操作。  .SILENT 前面已经介绍过,make在执行命令行时会回显命令行内容,在命令行前增加“@”字符将抑制该命令行的回显。 如果增加该目标,所有的命令行不再回显,相当于在每个命令行前均增加了“@”字符。  .PRECIOUS 当收到一个信号或从shell命令返回非零的错误码时,make删除它所有已建立的文件。但有些文件即使出了错误,用户也不想让make删除,这些文件可以作为.PRECIOUS目标的参数。它可以在一个makefile中出现多次,每一次都累积文件列表。  .SUFFIXES 它为makefile指定新的后缀规则,新的后缀规则作为.SUFFIXES的依赖表给出。.SUFFIXES可以在一个makefile中多次使用,每一次都将新的后缀规则加入以前的后缀规则中,如果.SUFFIXES的依赖表为空,则设置后缀规则表为空。 四 特殊的宏 为简单使用规则,make提供了几个特殊的宏:  $@ 整个当前目标名的值可以由宏“$@”来代替。  $《 当前的源文件由“$《”来代替。例如,在前面的例子中用到了$(CC) –c $《,其中的“$《”是所有要编译的.c文件。宏“$《”仅在后缀规则或.DEFAULT中有效。  $* 当前目标的基名由宏“$*”来代替。例如目标的名字是hello.o,则基名就是除去了后缀.o的hello。 以上介绍的特殊宏使用了make自身的规则,用户不可以改变。下表介绍了C中预定义的宏。 用途 宏 默认值 库文档汇编命令 AR ar ARFLAGS rv AS as ASFLAGS COMPILE.s $(AS) $(ASFLAGS) $(TARGET ARCH) C编译器命令 CC cc CFLAGS CPPFLAGS COMPILE.c $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET ARCH) –c LINK.c $(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET ARCH) 链接器命令 LD ld LDFLAGS rm命令 RM rm 后缀列表 SUFFIXES .o .c .c~ .s .s~ .S .S~ .ln .f .f~ .F .F~ .l .mod .mod~ .sym .def .def~ .p .p~ .r .r~ .y .y~ .h .h~ .sh .sh~ .cps .cps~ 五 makefile的应用 当调用make时,它在当前目录下搜索文件名是“makefile”或“Makefile”的文件,并执行。 如果不想使用上述缺省文件,可以使用命令行中的“-f”来指定文件,如将编写的makefile命名为mklib,则指定为“make –f mklib”。