我有一个makefile,想确保所有的规则都是按顺序执行的,也就是说,没有并行执行。
我相信我有三种方法可以实现这一目标:
- 有
.NOTPARALLEL
目标, - 通过调用
make
usingmake -j 1
, - 通过直接在 makefile 中设置标志,例如,
MAKEFLAGS := -j 1
这三者之间是否存在“最佳实践”,哪一个更强大?
例如,这样做是不是有点矫枉过正?
MAKEFLAGS := --jobs=1
.NOTPARALLEL:
all:foo bar
.NOTPARALLEL:
foo:bar
.NOTPARALLEL:
bar:
@echo "test"
?
是的,这太过分了。
就三个选项而言:
您永远不应该设置
MAKEFLAGS
,原因有两个:它会导致命令行上传递的任何标志出现问题,并且MAKEFLAGS
不能以可以在外部进行稳健修改的方式工作。要查看这两个问题的实际效果,请将@echo $(MAKEFLAGS)
规则添加到您的bar
配方中,然后运行make -n bar
.make -j 1
具有您所追求的效果,但是当您想暂时串行运行所有内容时,它是最合适的。如果您想限制使用的资源,或者您正在调试并行执行问题,这很有用。这也是默认设置,至少在 GNU Make 中是这样:默认情况下,Make 一次只运行一个任务。.NOTPARALLEL:
只需要指定一次,也有你想要的效果,并且当序列化要求是Makefile的一个属性时是合适的,即所有执行都应该是串行的,没有可能的外部影响。但是,如果您的构建将被大量使用,我认为最好花时间弄清楚为什么并行执行规则会导致问题,并添加适当的依赖项。GNU Make 支持order-only 先决条件,可用于强制排序而不强制“newness”依赖;在这种情况下,这些通常很有帮助。请参阅您在 SO 上找到的问题的答案。