Makefile每次都重建一切,为什么?

Ika*_*kok 2 makefile

我这里有简单的makefile:

SOURCES= $(wildcard *.c)
OBJECTS= $(patsubst %.c, %.o, $(SOURCES))
NAMES= $(patsubst %.c, %, $(SOURCES))
CC=gcc
CFLAGS= -Wall -c -o     
TASKS_IN_DIRS= $(addprefix obj/,$(OBJECTS)) $(addprefix bin/,$(NAMES))

all: $(NAMES)

$(NAMES): %: %.o $(OBJECTS)
    $(CC) -o bin/$@ obj/$^
$(OBJECTS): %.o: %.c 
    $(CC) $(CFLAGS) obj/$@ $<
clean:
    rm -rf $(TASKS_IN_DIRS)
Run Code Online (Sandbox Code Playgroud)
  1. 获取所有c文件名称.
  2. 从它们制作简单的名称(没有扩展名)和对象名称.
  3. 做事

重要的是 - 一切正常,但每次我打印make(编译和链接所有文件)都有效.即使我没有改变任何东西,而且我连续几次这样做,依赖关系出了什么问题?

我期待像"blabla是最新的"之类的东西.

The*_*sey 5

$(OBJECTS): %.o: %.c 
    $(CC) $(CFLAGS) obj/$@ $<
Run Code Online (Sandbox Code Playgroud)

正在查找当前目录中的.o文件.因为它们不在那里它正在重建它们.

以下是您想要的.

SOURCES= $(wildcard *.c)
OBJECTS:= $(patsubst %.c, %.o, $(SOURCES))
OBJECTS:= $(addprefix obj/,$(OBJECTS))
NAMES:= $(patsubst %.c, %, $(SOURCES))
NAMES:= $(addprefix bin/,$(NAMES))
CC=gcc
CFLAGS= -Wall -c -o
TASKS_IN_DIRS=$(OBJECTS) $(NAMES)

all: $(NAMES)

$(NAMES): $(OBJECTS)
    $(CC) -o $@ $<

obj/%.o: %.c
    $(CC) $(CFLAGS) $@ $<

clean:
    rm -rf $(TASKS_IN_DIRS)
Run Code Online (Sandbox Code Playgroud)


Jen*_*ens 5

你骗了.您承诺每个$(NAMES)目标都在当前目录中创建其目标文件,但由于$(CC) -o bin/$@ obj/$^它是在bin目录中创建的.

在下次make调用时,它无法找到目标文件并再次运行每个命令.

Makefile的硬性和快速规则:每个非PHONY目标必须$@在其命令的某处使用plain 来指示它创建的文件.