定义
make: 工程管理器,顾名思义,就是指管理较多的文件。
make工程管理器也就是个“自动编译管理器”,这里的“自动”是指它能构根据文件时间戳自动发现更新过的文件而减少编译的工作量,同时,它通过读入Makefile文件的内容来执行大量的编译工作。
Makefile或makefile是make读取的唯一配置文件。
makefile格式
目标:依赖
命令
注意:命令前要使用TAB键
理解:通俗来讲,依赖(相当于原材料) ==> 命令(相当于加工过程) ==>目标(相当于产物)
makefile 根据以下步骤编写:
gcc -c xx.c -o xx.o
gcc xx.o -o xx
例如: 写一个test.c文件,再写一个makefile文件,用make工具管理文件
执行make命令
如果光执行make会自动找第一个目标,也可以make后面跟目标名称。
添加伪目标:
伪目标:它的目的并不是创建目标文件(所以称作“伪”),而是想去执行这个目标下面的命令。比如想执行下面这个清空的命令:
test : test.ogcc test.o -o test
test.o:test.c
gcc -c test.c -o test.o
.PHONY:clean
clean:
rm -rf *.o test
常用指令
makefile变量
自定义变量
自己定义的变量:一般用大写表示变量名,取变量的值用$(变量名)
= 递归方式展开
:= 直接赋值(当前的值是什么就立即赋值)
+= 追加新的值
?= 判断之前是否定义,如果定义了,不重新赋值,否则赋值
预定义变量
系统预先定义好的一些变量,可能有默认值可能没有默认
RM 文件删除程序的名称,默认值为rm -f
CC C编译器的名称,默认值为cc
CPP C预编译器的名称,默认值为$(CC) –E
CFLAGS C编译器的选项,无默认值。
OBJS 生成的二进制文件或目标文件,自己定义
CC=gcc
OBJS=test.o add.o
CFLAGS=-c -g -Wall #-c编译 -g加调试 -Wall显示警告
#CC=arm-linux-none-gnueabi-gcc #交叉编译链
test:$(OBJS)
$(CC) $(OBJS) -o test
test.o:test.c
$(CC) $(CFLAGS) test.c -o test.o
add.o:add.c
$(CC) $(CFLAGS) add.c -o add.o
.PHONY:clean
clean:
$(RM) *.o test
自动变量
$< 第一个依赖文件的名称
$^ 所有不重复的依赖文件,以空格分开
$@ 目标文件的完整名称
OBJS=test.o fun.o
CFLAGS=-c -g -Wall #-c编译 -g加调试 -Wall显示警告
CC=gcc
#CC=arm-linux-none-gnueabi-gcc #交叉编译链
test:$(OBJS)
$(CC) $^ -o $@
test.o:test.c
$(CC) $(CFLAGS) $< -o $@
fun.o:fun.c
$(CC) $(CFLAGS) $< -o $@
.PHONY:clean
clean:
$(RM) *.o test
可以用%.c 和%.o代替所有的.c和.o文件,循环把每一个.c变成.o, 最终版本把要编译的.o放到OBJS中就可以了。
OBJS=test.o fun.o
CFLAGS=-c -g -Wall #-c编译 -g加调试 -Wall显示警告
CC=gcc
#CC=arm-linux-none-gnueabi-gcc #交叉编译链
test:$(OBJS)
$(CC) $^ -o $@
%.o:%.c
$(CC) $(CFLAGS) $< -o $@
.PHONY:clean
clean:
$(RM) *.o test
make指令
make -s: 隐藏执行的指令
make -C 目录: 进入指定目录执行make指令
总结: