1、MAKECMDGOALS
make 在执行时会设置一个特殊变量 -- "MAKECMDGOALS" ,该变量记录了命令行参数指定的终极目标列表,没有通过参数指定终极目标时此变量为空。该变量仅限于用在特殊场合(比如判断),在 Makefile 中最好不要对它进行重新定义。
在敲命令:make run时,MAKECMDGOALS这个变量的值就被设为了run
// 在makefile中判断是否执行了某个命令 ifeq($(MAKECMDGOALS),$(findstring $(MAKECMDGOALS),run,cmp,ncrun) 当执行的是run、cmp、ncrun就执行这些处理 endif
1、MAKE
$(MAKE)变量其实就是存储的make字符
taget: @$(MAKE) run tc=xxx // 等效于 taget: @make run tc=xxx