举例一个makefile 的代码
时间: 2023-06-17 12:06:27 浏览: 103
下面是一个简单的 makefile 示例,它包含了一个目标文件和两个依赖文件:
```
CC = gcc
CFLAGS = -Wall -Wextra -Werror
all: program
program: main.o helper.o
$(CC) $(CFLAGS) -o program main.o helper.o
main.o: main.c helper.h
$(CC) $(CFLAGS) -c main.c
helper.o: helper.c helper.h
$(CC) $(CFLAGS) -c helper.c
clean:
rm -f program *.o
```
上述 makefile 中,首先定义了编译器和编译选项的变量。然后,定义了一个名为 `all` 的目标,它依赖另一个名为 `program` 的目标。`program` 目标依赖于 `main.o` 和 `helper.o` 两个文件,分别通过将它们编译成目标文件,然后将它们链接成可执行文件 `program`。`main.o` 和 `helper.o` 这两个文件分别依赖于 `main.c` 和 `helper.c`,并且都需要头文件 `helper.h`。最后,定义了一个名为 `clean` 的目标,用于清除生成的目标文件和可执行文件。
相关问题
makefile是什么?举例解析makefile文件,推荐makefile学习资料
Makefile是一种用来描述程序构建过程的文件,它可以让程序员定义一组规则,指导编译器和链接器如何把源代码编译成可执行程序。Makefile文件中包含了源文件、目标文件、依赖关系和编译选项等信息,它可以让程序员很方便地管理和维护程序的构建过程。
下面是一个简单的Makefile文件的示例:
```makefile
# Makefile示例
# 定义编译器和编译选项
CC = gcc
CFLAGS = -Wall
# 定义目标文件和依赖关系
TARGET = hello
OBJS = hello.o
# 构建目标文件
all: $(TARGET)
$(TARGET): $(OBJS)
$(CC) $(CFLAGS) -o $@ $^
# 构建目标文件的依赖关系
hello.o: hello.c
$(CC) $(CFLAGS) -c $< -o $@
# 清除中间文件
clean:
rm -f $(OBJS) $(TARGET)
```
在这个Makefile文件中,我们定义了编译器和编译选项,目标文件和依赖关系,以及构建目标文件的规则和清除中间文件的规则。通过运行`make`命令,我们就可以自动构建出可执行程序。
推荐学习资料:
1. GNU make手册:https://www.gnu.org/software/make/manual/
2. 《跟我一起写Makefile》:https://seisman.github.io/how-to-write-makefile/introduction.html
3. 《Makefile入门》:https://www.ruanyifeng.com/blog/2015/02/make.html
举例说明makefile依赖文件
假设有以下三个文件:
- main.c:主程序源代码文件
- func.c:函数库源代码文件
- header.h:头文件,包含函数声明
那么,我们可以编写以下makefile:
```
CC = gcc
CFLAGS = -Wall -Werror
LDFLAGS = -lm
main: main.o func.o
$(CC) $(LDFLAGS) $^ -o $@
main.o: main.c header.h
$(CC) $(CFLAGS) -c $< -o $@
func.o: func.c header.h
$(CC) $(CFLAGS) -c $< -o $@
clean:
rm -f *.o main
```
这个makefile的作用是编译生成可执行文件main。其中,可执行文件main依赖于main.o和func.o两个目标文件,而这两个目标文件分别依赖于对应的源代码文件和头文件。在makefile中,我们用依赖关系的方式来描述这些文件之间的关系,从而告诉make工具如何生成目标文件和可执行文件。
如果我们修改了func.c文件,那么make工具会自动检测到main.o和func.o需要重新编译,从而重新生成可执行文件main。这样,我们就可以方便地管理和维护程序中的各个文件。
阅读全文