makefile学习(一)

目录

一、make和makefile

1、什么是make?

2、什么是makefile?

3、make和makefile之间的关系

4、最简单的makefile示例

5、make程序的使用示例

6、make程序的简写实例

7、小结

二、初识makefile的结构

1、makefile的意义

2、makefile中的元素含义

3、规则中的注意事项

4、规则中的注意事项

5、—个makefile的依赖示例

6、依赖规则

7、第一个 make的编译案例

8、小结

三、伪目标的引入

1、makefile 中的目标究竟是什么?

2、下面的代码有什么意义?

3、makefile 中的伪目标

4、伪目标的语法:先声明,后使用

5、伪目标的妙用:规则调用(函数调用)

6、技巧:绕开.PHONY 关键字定义伪目标

7、小结

四、变量和不同的赋值方式

1、变量和不同的赋值方式


一、make和makefile

1、什么是make?

  • 解析源程序之间的依赖关系
  • 根据依赖关系自动维护编译工作
  • 执行宿主操作系统中的各种命令
     

2、什么是makefile?

makefile是一个描述文件

  • 定义一系列的规则来指定源文件编译的先后顺序
  • 拥有特定的语法规则,支持函数定义和函数调用
  • 能够直接集成操作系统中的各种命令
     

3、make和makefile之间的关系

  • makefile中的描述用于指导make程序如何完成工作;
  • make根据makefile中的规则执行命令,最后完成编译输出。

4、最简单的makefile示例

注意目标后的命令需要用Tab 键('\t’)隔开。

  • 注意:在gedit中,若不禁止空格代替制表符,则会出错。

                  

  • 如何进行修改呢?

修改后便正常了。

5、make程序的使用示例

make -f mf.txt he1lo

功能说明∶以hello 关键字作为目标查找mf.txt文件,并执行hello 处的命令。

6、make程序的简写实例

make hello

功能说明︰以hello 关键字作为目标查找makefileMakefile文件(无后缀),并执行hello 处的命令。

make

功能说明∶查找makefile Makefile文件中最顶层目标,并执行最顶层目标的命令。
 

7、小结

  • make只是一个特殊功能的应用程序
  • make用于根据指定的目标执行相应的命令
  • makefile用于定义目标和实现目标所需的命令
  • makefile有特定的语法规则,支持函数定义和调用
     

二、初识makefile的结构

1、makefile的意义

  • makefile用于定义源文件间的依赖关系
  • makefile 说明如何编译各个源文件并生成可执行文件
  • 依赖的定义:

targets : prerequisites ; command1

'\t' command2

或者

targets : prerequisites

\t' command1

'\t' command2

  • prerequisites :依赖,可省略
  • command:命令,可以有多条

2、makefile中的元素含义

targets

  • 通常是需要生成的目标文件名
  • make所需执行的命令名称

prerequisities

  • 当前目标所以依赖的其它目标或文件

command

  • 完成目标所需要执行的命令

3、规则中的注意事项

targets 可以包含多个目标

  • 使用空格对多个目标名进行分隔

prerequisites 可以包含多个依赖

  • 使用空格对多个依赖进行分隔

4、规则中的注意事项

[ Tab ]键‘\t'

  • 每一个命令行必须以[ Tab ]字符开始
  • [ Tab ]字符告诉make 此行是一个命令行

续行符\

  • 可以将内容分开写到下一行,提高可读性

5、—个makefile的依赖示例

all : test
       echo "make all"
test :
       echo "make test"

6、依赖规则

  • 当目标对应的文件不存在,执行对应命令
  • 当依赖在时间上比目标更新,执行对应命令(依赖没有修改,就跳过)
  • 当依赖关系连续发生时,对比依赖链上的每一个目标

小技巧:makefile 中可以在命令前加上@符,作用为命令无回显

7、第一个 make的编译案例

  • 相互依赖关系:

小技巧:工程开发中可以将最终可执行文件名all同时作为makefile 中第一条规则的目标。

再次剖析当依赖在时间上比目标更新,执行对应命令

8、小结

  • makefile 用于定义源文件间的依赖关系
  • makefile说明如何编译各个源文件并生成可执行文件
  • makefile 中的目标之间存在连续依赖关系
  • 依赖存在并且命令执行成功是目标完成的充要条件

三、伪目标的引入

1、makefile 中的目标究竟是什么?

默认情况下

  • make认为目标对应着一个文件
  • make比较目标文件和依赖文件的新旧关系,决定是否执行命令
  • make 以文件处理作为第一优先级

2、下面的代码有什么意义?

实践:有趣的目标

注:rm:删除文件和目录的命令。

但是,如果我们在目录下创建一个clean文件,该命令就无法成功被执行。同时也说明了make 以文件处理作为第一优先级

那我们该怎么办呢?

3、makefile 中的伪目标

  • 通过.PHONY关键字声明一个伪目标
  • 伪目标不对应任何实际的文件
  • 不管伪目标的依赖是否更新,命令总是执行

4、伪目标的语法:先声明后使用

本质︰
伪目标是make 中特殊目标.PHONY的依赖

实践:使用伪目标

.PHONY:clean

##伪目标是make 中特殊目标.PHONY的依赖##

clean :

	rm *.o hello.out

5、伪目标的妙用:规则调用(函数调用)

.PHONY定义过的命令肯定会被执行。

.PHONY : rebuild clean all

rebuild : clean all

all : hello.out

clean :

	rm *.o hello.out

6、技巧:绕开.PHONY 关键字定义伪目标

原理∶如果一个规则没有命令或者依赖,并且它的目标不是一个存在的文件名;在执行此规则时,目标总会被认为是最新的。那么其后面的命令也一定会被执行。

实践:伪目标的高级应用

clean : FORCE

	rm *.o hello.out

FORCE :	

7、小结

  • 默认情况下,make认为目标对应着一个文件
  • .PHONY用于声明一个伪目标,伪目标不对应实际的文件
  • 伪目标的本质是make 中特殊目标.PHONY的依赖
  • 使用伪目标可以模拟“函数调用”
     

四、变量和不同的赋值方式

1、变量和不同的赋值方式

  • makefile中支持程序设计语言中变量的概念
  • makefile 中的变量只代表文本数据(字符串)
  • makefile 中的变量名规则
    变量名可以包含字符,数字,下划线
    不能包含:# = 空格
    变量名大小写敏感
     
  • 变量的定义和使用
     

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值