17_makefile基本语法(上)

makefile基本语法(上)

一.设置vim 首行缩进

vi /etc/vim/vimrc (rc 结尾的一般为配置文件)
输入set tabstop=4,保存后退出即可。便发现vim 打开后的缩进变成4 个空格了

image-20240310153706473

二.Makefile 基本语法

语法格式:
目标:依赖
(tab)命令
举例:

image-20240310153712475

目标:all
依赖:空
命令: gcc hello.c -o hello
上面的例子也可以写成:

image-20240310153730255

目标:all 和hello.o
依赖:hello.o 和hello.c
命令: gcc hello.c -o hello 和gcc -c hello.c
因为all 依赖hello.o 文件,所以要先执行gcc -c hello.c 得到hello.o 文件,然后才可以执行gcc hello.c -o hello。所以输入make 命令后执行顺序如下。

image-20240310153755102

在编译的时候,我们可以使用make 目标来编译,如果我们不指定目标的话,默认执行的是第一个目标所对应的规则。也就是说make 和make all 是一样的。如上面的例子。
接下来,我们使用make 目标的方法来编译。我们修改makefile 代码如下:

image-20240310153818253

然后我们输入命令make clean 就可以直接执行rm -rf *.o hello 命令。如下图所示:

image-20240310153828296

但是,我们在当前目录下不能有和makfile 目标名一样的文件。比如我在当前目录下创建一个名为clean 的文件,然后在执行make clean 命令就会报错。如下图所示:

image-20240310153835064

为了解决这个问题,makfile 引入了一个新的概念,叫做伪目标,我们使用伪目标来声明clean 就可以避免与当前目录下的同名文件发生冲突。
伪目标格式:
.PHONY:目标
所以,我们可以把上面的代码修改成如下图所示:

image-20240310153851801

然后我们在执行make clean 命令。尽管当前目录下有clean 同名文件,make clean 命令也可以执行成功。如下图所示:

image-20240310153910591

三.Makefile 变量和变量赋值

变量可以许多地方使用,比如目标,依赖,或者命令。
变量的赋值可以使用:= ?= := +=
变量的使用:通过$()来完成变量的引用。
示例1:
使用:=来赋值

image-20240310153917390

使用:=来给变量赋值,是立刻赋值,在执行var:=aaa 的同时变量值已经被确定了,所以最后打印为aaabbb,而不是cccbbb

image-20240310153924355

示例2:
使用=来赋值

image-20240310153936148

使用=来赋值,是延迟赋值,使用他来赋值是makfile 里面最后被指定的值。因为我们最后给变量var1赋值为ccc,所以最后打印为cccbbb,而不是aaabbb,如下图所示:

image-20240310153947685

示例3:
使用?=来赋值

image-20240310153954249

使用?=来赋值的意思为,如果var1 变量前面没有被赋值,那么就给他赋值为ccc,如果前面已经赋值了,就使用前面的值,所以,打印为aaabbb,而不是cccbbb,如下图所示。

image-20240310154004824

然后我们注释掉第一行代码,makefile 种的注释为#

image-20240310154015644

在运行就会打印cccbbb,因为前面没有给var1 变量赋值。如下图所示

image-20240310154027798

示例4:使用+=来赋值
使用+=来赋值是追加赋值,是在我们前面定义的好的字符串里面在添加进去新的字符串,所以运行会打印aaa bbbccc。不过中间会有空格,如下图所示;

image-20240310154039716

使用+=也类似与我们这样赋值,如下图所示:

image-20240310154045901

如果赋值很长,我们也可以使用换行符\,如下图所示

image-20240310154051059

四.自动化变量

这里介绍三个最常用的自动化变量:
$@:表示所有目标
$<:表示第一个依赖文件,如果依赖模式是%,那么它就表示一系列文件。
(%为通配符,类似linux 上的*)
$^:表示所有依赖。
在了解这个三个自动化变量之前,我们先来写一个程序:
main.c

image-20240310154109249

hello.c

image-20240310154115174

hello.h

image-20240310154119427

Makefile

image-20240310154124007

使用这个makefile 虽然也可以成功编译,但是,一旦编译的文件多了,如果我们还这样来编写makfile 就会变得非常的复杂。所以,自动化变量就排上用场啦。
接下来我们一步一步的来简化我这个makefile。
简化一:用变量表示依赖文件

image-20240310154139442

后面如果我们在增加依赖文件的话,我们直接在变量var 后面增加就可以了。
简化二:
使用通配符%,和自动化变量$@ $<替代依赖和目标,简化完如下图所示:

image-20240310154151438

简化三:使用自动化变量$^表示所有依赖,简化完如下图所示:

image-20240310194144079

posted @ 2024-03-31 22:05  爱吃冰激凌的黄某某  阅读(12)  评论(0编辑  收藏  举报