使用.c = .o和$ <了解Makefile

use*_*406 4 c makefile

这是我的第一个Makefile,我无法弄清楚使用的一些语法.问题标在下面

C := gcc

CFLAGS := -Wall -Werror -std=

PROG := program_1\
    program_2\
    program_3

SRCS := program_1.c \
    program_2.c \
    program_3.c

OBJS := ${SRCS:.c=.o} 

all: ${OBJS}
  ${CC} ${OBJS} -o ${PROG}

clean:
    rm -f ${PROG} ${OBJS}


.c.o:
    ${CC} ${CFLAGS} -c $<
Run Code Online (Sandbox Code Playgroud)
  1. 什么.c = .o是什么意思?在OBJS中:= $ {SRCS:.c = .o}

  2. 不知道$ <mean here和.co?.co:$ {CC} $ {CFLAGS} -c $ <

Mar*_*eck 9

首先,你Makefile有一个bug,它没有达到预期的目标.你试过吗?

第二,写得不好; 不遵循最佳实践.

因此,我将首先向您展示Makefile的更好版本,无论是正确的,还是使用最佳实践编写的:

CFLAGS := -Wall -Werror -std=

SRCS := program_1.c \
    program_2.c \
    program_3.c

OBJS := ${SRCS:c=o} 
PROGS := ${SRCS:.c=}

.PHONY: all
all: ${PROGS}

${PROGS} : % : %.o Makefile
    ${CC} $< -o $@

clean:
    rm -f ${PROGS} ${OBJS}

%.o: %.c Makefile
    ${CC} ${CFLAGS} -c $<
Run Code Online (Sandbox Code Playgroud)

现在,您的问题的答案是:

${SRCS:.c=.o}指,取所述变量值${SRCS},这是一个由空格分隔单词组成的字符串,并且对于每个字,替换后缀.c.o .我删除.了我的代码,因为它不需要,并且通常只在点后面替换后缀.

如果您熟悉该语法,则此语法类似于bash字符串后缀替换(对于一个单词).

$<当在"食谱"中使用时,意味着"第一个先决条件" - 在:上面的行之后的第一件事.

并且最后一个问题不再相关: .o.c语法已过时,目前不推荐.

请看看我的"十诫" - 我在这篇文章中的答案:

makefile强制库依赖顺序

,他们会给你一个关于最佳实践的想法.然后你也可以阅读GNU Make手册,关于引号中的上述术语,我在这里没有解释.

  • 还有一个问题。我看到你放置了 %.o: %.c Makefile,为什么你把 Makefile 作为先决条件,我正在查看其他在线资源,似乎 %.o : %.c 就足够了? (2认同)
  • @user3630406 好吧,思考“先决条件”的正确方法是,列出所有文件,如果它们发生变化,生成的目标也可能会发生变化。因此,如果 Makefile 发生变化,则该目标的配方可能发生变化,在这种情况下,生成的目标也可能发生变化。因此,最好在所有先决条件行上列出所有包含的 makefile。 (2认同)