makefile在同一目录下编译出多个可执行文件

时间:2021-07-05 13:50:48
LIBRARY +=  -ltpn_agent -ltpn_effect -ltpn_proc -lhiredis  -ljson
LDFLAGS += --as-needed
SRCS = $(wildcard *.c)
OBJS = $(patsubst %.c, %.o, $(SRCS))
TARGETS = $(SRCS:%.c=%)

$(info $(OBJS))
$(info $(TARGETS))

all : $(TARGETS)

$(TARGETS): %: %.o
$(CC) $(LDFLAGS) $(LIBRARY) -o $@ $<

$(OBJS) : %.o: %.c ./tpn_utils_common.h
$(CC) -c $(CFLAGS) -o $@ $<


clean :
@rm -rf $(TARGETS) $(OBJS)

#.SUFFIXES:
.PHONY : all clean

需要注意点:

  1. 自动化变量,就是这种变量会把模式中所定义的一系列的文件自动地挨个取出,直至所有的符合模式的文件都取完了。
    自动化变量只应出现在规则的命令中,否则后果不可预测

  2. $@ 表示规则中的目标文件集。
    在模式规则中,如果有多个目标,那么$@就是匹配于目标中模式定义的集合。
    注意,其目标是一个一个取出来的

  3. $< 依赖目标中的第一个目标名字。
    如果依赖目标是以模式(即% )定义的,那么$<将是符合模式的一系列的文件集。
    注意,其是一个一个取出来的

  4. $^ 所有的依赖目标的集合。以空格分隔。
    如果在依赖目标中有多个重复的,那个这个变量会去除重复的依赖目标,只保留一份。

  5. $+ 这个变量很像$^,也是所有依赖目标的集合,只是它不去除重复的依赖目标

  6. .h头文件只应该出现在依赖中,不应该出现在编译的命令行中。(编译的时候会被预处理器包含到.c文件中)