Make:默认构建目标(终极目标)

相关文章

Make:目标(Target)构建的详细和依赖项的处理过程(个人总结)


默认情况下make命令的构建从第一个没有 . 前缀的目标(target)开始(除非有 . 前缀的目标中有一个或更多 / ,这是GNU make官方手册说的)。实际上,放在第一个的./.target目标也不会被构建,所以更准确的概括是,make命令从不是隐藏文件的目标开始。该目标称为默认终极目标(goal),终极目标是make最终想要更新的的目标。可以使用命令行覆盖makefile的默认终极目标,即将目标名作为参数传递给make命令。当出现多目标的规则时(较少见,一般情况下一个规则就是一个目标),目标列表中的第一个目标是默认终极目标。使用.DEFAULT_GOAL内置特殊变量也可以覆盖makefile的默认终极目标,在没有使用命令行指定终极目标时,设置该变量对应的值可以改变终极目标。

如下代码中,target1是默认终极目标,target2是目标。

复制代码
target1:target2
    @echo "Building target1"

target2:
	@echo "Building target2"

如下代码中,target是默认终极目标。

复制代码
.target:target
    @echo "Building .target"

target:
	@echo "Building target"

如下代码中,在命令行将终极目标改为了target2。

复制代码
target1:target2
    @echo "Building target1"

target2:
	@echo "Building target2"


//以下是CMD
$make target2

如下代码中,终极目标是target1。

复制代码
target1 target2:
    @echo "Building target1 2"

target3:
	@echo "Building target3"

如下代码中,终极目标是target2。

复制代码
.DEFAULT_GOAL = target2
target1:target2
    @echo "Building target1"

target2:
	@echo "Building target2"


//以下是CMD
$make //这里不能指定终极目标

参考资料:GNU Make MANUAL (GNU make Version 4.4.1)

相关推荐
f***R83 分钟前
解决bad SQL grammar []; nested exception is java.sql.SQLSyntaxErrorException
java·数据库·sql
T***19203 分钟前
实操解决Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错的问题
数据库·postgresql
·云扬·17 分钟前
Redis性能测试实战:掌握redis-benchmark工具用法与集群压测技巧
数据库·redis·缓存
2401_8370885021 分钟前
秒杀优化—基于 Redis 完成秒杀下单
数据库·redis·缓存
爬山算法31 分钟前
Redis(144)Redis的Cluster的节点通信是如何实现的?
数据库·redis·缓存
运维-大白同学1 小时前
2025最全面开源devops运维平台功能介绍
linux·运维·kubernetes·开源·运维开发·devops
梦在深巷、1 小时前
linux系统防火墙之iptables
linux·运维·服务器
AI绘画小331 小时前
Web 安全核心真相:别太相信任何人!40 个漏洞挖掘实战清单,直接套用!
前端·数据库·测试工具·安全·web安全·网络安全·黑客
I***26152 小时前
数据库操作与数据管理——Rust 与 SQLite 的集成
数据库·rust·sqlite
百***48072 小时前
redis连接服务
数据库·redis·bootstrap