Linux中make命令和makefile文件的编写,最后附完整代码。

前言:

首先我们必须要知道:make是一个命令  ,makefile是一个文件。

目录

一:makefile三要素

二:makefile中的变量与常用函数

1:普通变量的定义和使用

2:自动变量

3:常用函数

4:目标与伪目标

三:makefile的总体简介

四:makefile的编写


一:makefile三要素

目标:最终要生成的目标文件

依赖项:目标文件由哪些文件生成

依赖关系:如何使依赖项生成目标文件

在编写makefile文件时,目标是必须要存在的,对于依赖项和依赖关系,可以没有。

二:makefile中的变量与常用函数

1:普通变量的定义和使用

那么如果还要使用普通变量 j,也需要特定的格式 $(j) 才可以 。

2:自动变量

这些变量是makefile文件中特有的,他们每一个都代表着特别的含义。

$^:代表着目标的所有依赖项目

$@:代表目标

$<:代表目标的第一个依赖项

$?:代表目标的第一个变化的依赖项(这个用到比较少)

注意:这些自动变量只能使用在依赖关系中。

3:常用函数

wildcard:查找指定目录下的指定类型文件

srcFiles=$(wildcard  *.c)//获取当前工作目录下所有的 .c 文件,交给变量srcFiles(当然这里也可以查找其他类型的文件)

patsubst:匹配替换

objFiles=$(patsubst %.c,%.o,$(srcFiles))//将$(srcFiles)中所有的.c文件替换成.o文件交给变量objFiles。(这里注意使用变量时必须遵守的格式:$(变量名)

4:目标与伪目标

其实对与伪目标而言,它只是比目标多一个  .PHONY:修饰,这里的app就是目标,clean就是伪目标

 二者的区别在于:

伪目标:总是可以被执行。

目标:当它的依赖项没有发生改变时,他是不能被二次执行的。

三:makefile的总体简介

-:代表当前命令错误时,继续执行下一条命令

@:代表不要打印当前命令行 

四:makefile的编写

  1 srcFiles=$(wildcard *.c)
  2
  3 objFiles=$(patsubst %.c,%.o,$(srcFiles))
  4
  5 app:$(objFilesj)
  6   gcc $^ -o $@
  7
  8 %.o:%.c
  9   gcc -c $< -o $@
 10
 11 .PHONY:clean
 12 clean:
 13   -@rm -f *.o
 14   -@rm -f app

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值