Makefile基础教学(include的使用方法)
  micz61TEX78l 2023年11月02日 45 0

(文章目录)


前言

本篇文章将讲解include的使用方法,在C语言中使用include是包含头文件,那么在makefile当中使用include的作用是什么呢?

一、include在makefile中的概念介绍

在 Makefile 中,include 用于在当前 Makefile 中包含另一个 Makefile 或者一个设置环境变量的脚本。可以使用 include 将一个大型的 Makefile 分成多个小的 Makefile,方便维护和管理。

include 可以在 Makefile 的任意位置使用。它会读取并处理指定文件中的命令和变量,然后将它们合并到当前的 Makefile 中。

二、include使用示例

下面使用了include来包含了makefile1这个文件。 makefile:

include makefile1

all : 
	@echo "this is all"

makefile1:

test : 
	@echo "this is test-makefile1"

运行结果: 在这里插入图片描述 这里使用了include包含makefile1其实和C语言中的效果是一样的,就是将makefile1中全部的代码搬运到makefile中。 等效于:

test : 
	@echo "this is test-makefile1"
	
all : 
	@echo "this is all"

三、include中需要注意的一些操作

1. 在include前加-选项

在 include 前加 - 选项来忽略不存在的文件,不会导致 Make 命令执行失败。具体来说,加上 - 选项后,如果所包含的文件不存在,Make 会将其视为一个空文件,而不会产生错误信息。

-include nullfile

all : 
	@echo "this is all"

运行结果: 在这里插入图片描述

2. include触发规则创建了文件会发生什么

单看makefile中的内容会认为最后的结果是会执行到this is all,但是结果却不是这样。

.PHONY : all

-include test.txt

all : 
	@echo "this is all"
	
test.txt :
	@echo "creating $@ ..."
	@echo "other : ; @echo "this is other" " > test.txt

运行结果: 这是因为在test.txt下的命令创建出了test.txt这个文件,并且test.txt这个文件里面的内容为@echo "this is other,当创建好后include又会继续将test.txt这个文件里面的内容包含到当前的makefile当中。 在这里插入图片描述

3. include包含的文件夹存在

这里我们首先将test.txt和b.txt都创建了出来,按照之前学习过的当test.txt存在时,就不会执行相应目标下的命令了。

.PHONY : all

-include test.txt

all : 
	@echo "this is all"
	
test.txt : b.txt
	@echo "creating $@ ..."

执行结果: 结果还是执行了test.txt中的内容,这又是为什么? 在这里插入图片描述 当目标文件存在 将目标文件包含进当前makefile。

以目标文件名查找是否有对应规则。

比较规则的依赖关系,绝对是否执行规则的命令。

上面的代码就是检测到存在test.txt这个规则,比较后发现b.txt比test.txt更新那么就会执行对应的命令了。

总结

本篇文章讲解了include的使用,在makefile中使用include 可以带来很多便捷,但是有的时候使用错误也会导致很多问题,希望大家牢记本篇文章中讲解到的知识点。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  micz61TEX78l   2023年11月19日   31   0   0 3c插入图片寄存器
micz61TEX78l