makefile首先会把其遇到的第一个目标作为主目标;makefile会依次完成被主目标依赖的目标。makefile尽力做到一点:make时只加入有改动的部分,这是通过如果主目标依赖的目标为一个文件,如果该文件已生成,那么检查目标依赖文件,如果依赖文件未更新,不进行改动,否则链接入更新;这说明若想做到makefile的最小更新,依赖文件需要是精确的编译出的.o文件名,否则make会认为目标未生成而每次都执行命令(已实验)。
这样如果对于Make target,如target为clean,make发现clean没有任何依赖,且当文件夹中有一个文件名为clean,就会认为clean文件不需要更新而不做任何事。因此像clean这种没有依赖,并且还需要执行的target需要声明为PHONY,表示每次必须执行,如果我的理解是对的,我认为网上滥用的.PHONY:all是没有必要的,因为all有依赖的target。
经过实验,发现确实文件夹中存在all时也会正常运行,这是因为all有依赖的target。