makefile编译举例

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

你可能感兴趣的:(makefile)