多文件编译makefile写法
makefile基本语法
target... : prerequisites ...
command
#目标 先决条件
#命令
通过make
生成可执行文件。
- make会在当前目录下找名字叫“Makefile”或“makefile”的文件。
- 如果找到,它会找文件中的第一个目标文件(target)。
- 如果edit所依赖的.o文件也存在,那么make会在当前文件中找目标为.o文件的依赖性,如果找到则再根据那一个规则生成.o文件。(这有点像一个堆栈的过程)
- 当然,你的C文件和H文件是存在的啦,于是make会生成 .o 文件,然后再用 .o 文件声明make的终极任务,也就是执行文件edit了。
使用makefile
的优点
- 如果这个工程没有编译过,那么我们的所有C文件都要编译并被链接。
- 如果这个工程的某几个C文件被修改,那么我们只编译被修改的C文件,并链接目标程序
- 如果这个工程的头文件被改变了,那么我们需要编译引用了这几个头文件的C文件,并链接目标程序
makefile
中符号变量:
$@
目标文件
@^
所有的依赖文件
@<
第一个依赖文件
makefile
中@
相当于解析变量的符号
# 在makefile中可以自己定义变量,赋值并使用,解析变量在我看来是一种替换,类似于c中的宏定义
cc=gcc
objects = main.o kbd.o command.o display.o \
insert.osearch.o files.o utils.o
edit : $(objects)
cc -o edit $(objects)
main.o : main.c defs.h
cc -c main.c
kbd.o : kbd.c defs.h command.h
cc -c kbd.c
command.o : command.c defs.h command.h
cc -c command.c
display.o : display.c defs.h buffer.h
cc -c display.c
insert.o : insert.c defs.h buffer.h
cc -c insert.c
search.o : search.c defs.h buffer.h
cc -c search.c
files.o : files.c defs.h buffer.h command.h
cc -c files.c
utils.o : utils.c defs.h
cc -c utils.c
.PHONY : clean #PHONY说明clean是一个伪目标文件
clean :
rm edit $(objects)
下面给一种我常用的makefile
写法
CC = gcc
OBJ = main
OBJS =
OBJS += main.o
OBJS += collect_port.o
OBJS += fb.o
OBJS += mqtt.o
OBJS += log.o
OBJS += sql.o
OBJS += tpool.o
INCLUDE_PATH = ./include
CFLAGS = -I $(INCLUDE_PATH)
$(OBJ):$(OBJS)
$(CC) $(OBJS) -lpaho-mqtt3c -lsqlite3 -lpthread -o $(OBJ)
$*.o : $*.c
$(CC) $^ -c -o (CFLAGS) $@
.PHONY:clean
clean:
rm *.o main
贴一个之前看过的写的比较详细的文章
makefile介绍