首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

makefile变量赋值

大家好,又见面了,我是全栈君 在定义变量的值时,我们可以使用其它变量来构造变量的值,在Makefile中有两种方式来在用变量定义变量的值。...先看第一种方式,也就是简单的使用“=”号,在“=”左侧是变量,右侧是变量的值,右侧变量的值可以定义在文件的任何一处,也就是说,右侧中的变量不一定非要是已定义好的值,其也可以使用后面定义的值。...可见,变量是可以使用后面的变量来定义的。...“MAKELEVEL”,其意思是,如果我们的make有一个嵌套执行的动作(参见前面的“嵌套使用make”),那么,这个变量会记录了我们的当前Makefile的调用层数。...因为在操作符的右边是很难描述一个空格的,这里采用的技术很管用,先用一个 Empty变量来标明变量的值开始了,而后面采用“#”注释符来表示变量定义的终止,这样,我们可以定义出其值是一个空格的变量

1.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    makefile

    前言 这几天的实验让我觉得有必要学习一下makefile 参考博客:博客 会不会写makefile,从一个侧面说明了一个人是否具有完成大型工程的能力 makefile带来的好处是自动化编译 规则...输入 make clean 才可以执行 变量 出于对makefile的易维护性的考虑,引入了变量的概念: objects=main.o kbd.o command.o display.o \ insert.o...读入被include的其它Makefile。 初始化文件中的变量。 推导隐晦规则,并分析所有规则。 为所有的目标文件创建依赖关系链。 根据依赖关系,决定哪些目标要重新生成。 执行生成命令。...文件,上级的makefile变量可以传到下一级: export ; 传递所有变量的话只需一个export,不需要任何变量名称 变量 变量可以使用变量: foo=$(bar)bar=$(ugh...变量值的替换 foo :=a.o b.o c.obar :=$(foo:.o=.c) 第二行把foo中的.o全部换为.c 追加变量值: objects = main.o foo.o bar.o utils.oobjects

    1.1K20

    makefile

    (2)变量定义:在Makefile中可以定义一系列的变量变量一般都是字符串,当Makefile被执行时,变量的值会被扩展到相应的引用位置上。...2.1 Makefile中的变量 (1)Makefile中定义的变量,与C/C++语言中的宏一样,代表一个文本字串,在Makefile被执行时候变量会自动地展开在所使用的地方。...(3)Makefile变量是大小写敏感的。“foo”、“Foo”和“FOO”是三个不同的变量名。传统的Makefile变量名是全大写的命名方式。...2.4 Makefile中的函数 在Makefile中可以使用函数来处理变量,从而让命令或规则更为的灵活和具有智能,函数调用,很像变量的使用,也是以“$”来标识的,函数调用后,函数的返回值可以当做变量来使用...-I DIR 当包含其他 makefile 文件时,可利用该选项指定搜索目录。 -n 只打印要执行的命令,但不执行这些命令。

    2K00

    makefile 基础、进阶及常用 makefile

    gcc main.o add.o sub.o mul.o -o app makefile 变量 接下来我们引入 makefile 变量机制,来修改一下上面的 makefile 文件。...,注意变量在使用的时候要加 $(),中间变量名字。...makefile 自动变量 makefile 中有一些预定义的变量,你可以理解它像是 C 语言中的一些关键字,分别有不同的意义,我们列举几个常用的自动变量(其他还有很多),通过上面的 makefile...如下所示: # 获取所有 .c 文件的列表赋值给 src 变量 src = $(wildcard *.c) # 根据 src 变量获取 .o 文件列表存放到 obj 变量中 obj = $(patsubst...我们也可以添加一些自定义的变量,让以后 makefile 维护起来更方便: # 获取所有 .c 文件的列表赋值给 src 变量 src = $(wildcard *.c) # 根据 src 变量获取 .

    37510

    Makefile总结

    变量在声明时赋予初值,引用变量时需要在变量名前加上”$”符号,用小括号”()”或大括号”{}”把变量括起来。...用=定义一个变量,并且赋值(等号两边可以加空格) 用+=追加字符串 例: A = src echo $(A) @echo $(A) ##只输出echo的结果,不显示执行的命令 可对上述的Makefile...: $@ 目标文件 $^ 依赖项列表 $< 依赖项列表第一项 通过make -p可以查看很多自定义的变量,如CC(默认值为cc),RM(默认值为rm -f) 可对上述的Makefile再进行修改: CC...在调用子目录Makefile,有时我们需要传递参数,两种方法: 方法一: 在上层Makefile中使用”export”关键字对要传递的变量进行声明。...export DIR = /var/log 相反如不希望传递变量,可以使用”unexport”关键字 方法二: 在调用子Makefile命令上指定变量

    96310

    Makefile教程

    Makefile中我们要定义一系列的变量变量一般都是字符串,这个有点你C语言中的宏,当Makefile被执行时,其中的变量都会被扩展到相应的引用位置上。 4.文件指示。...make会将整个Makefile展开后,再决定变量的值。也就是说,变量的值将会是整个Makefile中最后被指定的值。...(2)使用变量的替换引用 这里用到Makefile里的替换引用规则,即用指定的变量替换另一个变量。...all: echo "done" 上面”build debug”和”build release”之类的字符串根本不会打印出来。...7.10如何使用shell脚本给Makefile变量赋值 Makefile可以内嵌shell脚本,但是在内嵌的shell脚本只能读取Makefile变量,如何给Makefile变量赋值呢?

    4K53

    Makefile 的使用

    比如: A = $@ test: @echo $A 上述 Makefile 中,变量 A 的值在执行时才确定,它等于 test,是延时变量。...当然,一个规则也可以是用于解释怎样和何时执行一个动作,即打印提示信息。 一个 Makefile 文件可以包含规则以外的其他文本,但一个简单的 Makefile 文件仅仅需要包含规则。...3.3 Makefile 文件里的赋值方法 变量的定义语法形式如下: immediate = deferred immediate ?...; ‘file’ :变量‘variable’在 Makefile 中定义; ‘command line’ :变量‘variable’在命令行中定义; ‘override’ :变量‘variable...’在Makefile 中用 override 指令定义; ‘automatic’ :变量‘variable’是自动变量 (4)$(shell command arguments) 函数 shell

    4.3K42
    领券