【Linux】Makefile 编写教程

以下是一个简单的Linux Makefile编写实例,用于编译一个C语言程序:

CC = gcc
CFLAGS = -Wall -g
TARGET = myprogram
SRCS = main.c foo.c bar.c
OBJS = $(SRCS:.c=.o)

all: $(TARGET)

$(TARGET): $(OBJS)
	$(CC) $(CFLAGS) -o $@ $^

%.o: %.c
	$(CC) $(CFLAGS) -c $< -o $@

clean:
	rm -f $(OBJS) $(TARGET)

该Makefile包含以下几个部分:

  1. 定义变量:
  • CC:编译器。
  • CFLAGS:编译选项,包括-Wall(显示所有警告信息)和-g(生成调试信息)。
  • TARGET:目标程序名。
  • SRCS:源文件列表。
  • OBJS:目标文件列表。
  1. 定义规则:
  • all:默认规则,编译目标程序。
  • ( T A R G E T ) :目标程序规则,依赖于目标文件列表 (TARGET):目标程序规则,依赖于目标文件列表 (TARGET):目标程序规则,依赖于目标文件列表(OBJS),使用编译器 ( C C ) 和编译选项 (CC)和编译选项 (CC)和编译选项(CFLAGS)生成目标程序。
  • ( O B J S ) :目标文件规则,依赖于对应的源文件,使用编译器 (OBJS):目标文件规则,依赖于对应的源文件,使用编译器 (OBJS):目标文件规则,依赖于对应的源文件,使用编译器(CC)和编译选项$(CFLAGS)生成目标文件。
  • %.o:通配符规则,用于生成目标文件,依赖于对应的源文件,使用编译器 ( C C ) 和编译选项 (CC)和编译选项 (CC)和编译选项(CFLAGS)生成目标文件。
  • clean:清理规则,删除目标文件和目标程序。
  1. 执行规则:
  • make:执行默认规则,编译目标程序。
  • make clean:执行清理规则,删除目标文件和目标程序。

该Makefile可以根据实际情况进行修改,例如添加头文件路径、库文件路径和库文件等。

猜你喜欢

转载自blog.csdn.net/qq_37286579/article/details/130603140