makefile编译举例
# 定义编译器和编译选项
CC = gcc
CFLAGS = -Wall -Werror # 定义目标文件名
TARGET = myprogram # 定义需要编译的源文件目录和文件名
SRC_DIR1 = src1
SRC_DIR2 = src2 OBJ_DIR1 = obj1
OBJ_DIR2 = obj2 SRC_FILES1 = file1.c file2.c
SRC_FILES2 = file3.c file4.c OBJ_FILES1 = $(addprefix $(OBJ_DIR1)/, $(notdir $(patsubst %.c, %.o, $(SRC_FILES1))))
OBJ_FILES2 = $(addprefix $(OBJ_DIR2)/, $(notdir $(patsubst %.c, %.o, $(SRC_FILES2)))) # 默认目标,编译可执行文件
all: $(TARGET) # 编译目标文件
$(TARGET): $(OBJ_FILES1) $(OBJ_FILES2) $(CC) $(OBJ_FILES1) $(OBJ_FILES2) -o $(TARGET) # 编译源文件
$(OBJ_DIR1)/%.o: $(SRC_DIR1)/%.c mkdir -p $(dir $@) $(CC) $(CFLAGS) -c $< -o $@ $(OBJ_DIR2)/%.o: $(SRC_DIR2)/%.c mkdir -p $(dir $@) $(CC) $(CFLAGS) -c $< -o $@ # 清除生成的目标文件和可执行文件
clean: rm -rf $(OBJ_DIR1)/* $(OBJ_DIR2)/* $(TARGET)
这个Makefile中,我们定义了以下内容:
CC和CFLAGS变量分别指定编译器和编译选项。
TARGET变量定义了生成的可执行文件的文件名。
SRC_DIR1和SRC_DIR2变量定义了源文件的目录。
OBJ_DIR1和OBJ_DIR2变量定义了目标文件的目录。
SRC_FILES1和SRC_FILES2变量定义了源文件的文件名。
OBJ_FILES1和OBJ_FILES2变量定义了目标文件的文件名。
all是默认目标,它依赖于$(TARGET)目标,用于编译生成可执行文件。
( T A R G E T ) 目标依赖于 (TARGET)目标依赖于 (TARGET)目标依赖于(OBJ_FILES1)和$(OBJ_FILES2)目标,它使用编译器将目标文件链接成可执行文件。