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)目标,它使用编译器将目标文件链接成可执行文件。