一个简单的Makefile


此例子由三个C文件组成,写一个简单的makefile文件,来描述如何创建最终的可执行文件“test”。

C文件:add.c test.c sub.c

将所有.c文件生成一个test文件

  • 一步编译:.c --> exe
test:test.c add.c sub.c
	gcc test.c add.c sub.c -o test
  • 分步编译:预处理 编译 汇编 链接 .c --> .o --> exe
    先生成.o文件,在生成可执行文件test
test.o:test.c
	gcc -c test.c -o test.o
add.o:add.c
	gcc -c add.c -o add.o
sub.o:sub.c
	gcc -c sub.c -o sub.o
test:test.o add.o sub.o
	gcc test.o add.o sub.o -o test

但是按照此顺序进行操作只能得到test.o文件,不能得到test文件。
这是因为make执行的是Makefile中的第一个规则,此规则的第一个目标称之为“最终目的”或者“终极目标”。也就是make的依赖性:make会一层又一层地去找文件的依赖关系,直到最终编译目标文件,但是make只认一个目标文件,故需要把最终目标文件放在最前面;即正确代码如下所示:

test:test.o add.o sub.o
	gcc test.o add.o sub.o -o test
test.o:test.c
	gcc -c test.c -o test.o
add.o:add.c
	gcc -c add.c -o add.o
sub.o:sub.c
	gcc -c sub.c -o sub.o

即可得到最终的可执行文件test文件。

“伪目标”(phony targets)

即没有任何依赖只有执行动作的目标。
make clean:删除执行文件和所有的中间目标文件。
最后的 clean 是 Makefile 一般都会有的一个环节,通常也是放在文件的最后。主要是用来清除之前生成的 Object Files 和可执行文件

通过“.PHONY”特殊目标将“clean”目标声明为伪目标。
1.避免当磁盘上存在一个名为“clean”文件时,目标“clean”所在规则的命令无法执行
2.在命令行之前使用“-”,意思是忽略命令 “rm”的执行错误

test:test.o add.o sub.o
	gcc test.o add.o sub.o -o test test.o:test.c
	gcc -c test.c -o test.o
add.o:add.c
	gcc -c add.c -o add.o
sub.o:sub.c
	gcc -c sub.c -o sub.o
.PHONY:clean                                         //伪目标
clean:
	-rm *.o                                          //删除.o文件

自定义变量及赋值

  • = : 基本赋值
  • ?= : 已赋值,则不进行本次赋值
  • := :覆盖赋值(保留新)
  • += :追加赋值(旧不变,增加一个新值)

使用自定义变量:

SRC = test.o add.o sub.o
test:$(SRC)
	gcc $(SRC) -o test
test.o:test.c
	gcc -c test.c -o test.o
add.o:add.c
	gcc -c add.c -o add.o
sub.o:sub.c
	gcc -c sub.c -o sub.o
.PHONY:clean
clean:
	-rm *.o

自动变量

  • $* : 不包含扩展名的目标文件名称
  • $+ :所有依赖文件,包含重复,空格隔开
  • $^ :所有依赖文件,不重复,空格隔开
  • $< :所有依赖文件的第一个文件的名称
  • $@ :所有目标文件,包含重复,空格隔开

使用自动变量:

SRC = test.o add.o sub.o
test:$(SRC) 
   gcc $(SRC) -o $@
test.o:test.c
   gcc -c $^ -o $@
add.o:add.c
   gcc -c $^ -o $@
sub.o:sub.c
   gcc -c $^ -o $@
.PHONY:clean
clean:
   -rm *.o

隐含变量

                            含义                                 默认值
AR	             库文件维护程序的名称             	               ar
AS	                汇编程序的名称 	                               as
CC	                C 编译器的名称 	                               cc
CPP              	C 预编译器的名称  	                        $(CC) –E
CXX	                C++编译器的名称 	                               g++
FC	                FORTRAN 编译器的名称                            f77
RM	                文件删除程序的名称  	                         rm –f
ARFLAGS	            库文件维护程序的选	                           无
ASFLAGS	            汇编程序的选项	                               无
CFLAGS	            C 编译器的选项 	                               无
CPPFLAGS	        C 预编译的选项	                               无
CXXFLAGS           	C++编译器的选项 	                               无
FFLAGS	            FORTRAN 编译器的选项	                           无

使用隐含变量:

CC = gcc
CFLAGS = -c -Wall -g -I include
test:$(SRC) 
	$(CC)  $^ -o $@
test.o:test.c
	$(CC) $(CFLAGS) $^ -o $@
add.o:add.c
	$(CC) $(CFLAGS) $^ -o $@
sub.o:sub.c
	$(CC) $(CFLAGS) $^ -o $@
.PHONY:clean
clean:
	-rm *.o
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值