0.前言
从学习C语言开始就慢慢开始接触makefile,查阅了很多的makefile的资料但总感觉没有真正掌握makefile,如果自己动手写一个makefile总觉得非常吃力。所以特意借助博客总结makefile的相关知识,通过例子说明makefile的具体用法。
例说makefile大致分为4个部分
1.只有单个C文件
2.含有多个C文件
3.需要包括头文件路径
4.一个较为复杂的例子
【代码仓库】——makefile-example
代码仓库位于bitbucket,可借助TortoiseHg(GUI工具)克隆代码或者在网页中直接下载zip包。
1.三个C文件
三个文件位于同一个目录中。
【test.c】
#include <stdio.h> int main(void) { int a = 3; int b = 2; printf("a=%d\n", a); printf("b=%d\n", b); printf("a+b=%d\n", a+b); printf("a-b=%d\n", a-b); return 0; }
【test-add.c】
int add(int a, int b) { return a+b; }
【test-sub.c】
int sub(int a, int b) { return a-b; }
2.复习GCC指令
多个C文件和单个C文件的处理过程相似,此时-c或-o之后可以增加多个C文件或目标文件。
【编译源文件】
gcc -c test.c test-add.c test-sub.c
【链接目标文件】
gcc -o test test.o test-add.o test-sub.o
【执行目标文件】
./test
【控制台输出】
a=3
b=2
a+b=5
a-b=1
3.编写makefile文件
【makefile】
请替换其中的[tab],并以代码仓库中的makefile文件为主。
# 指令编译器和选项 CC=gcc CFLAGS=-Wall -std=gnu99 # 目标文件 TARGET=test # 源文件 SRCS=test.c test-add.c test-sub.c OBJS = $(SRCS:.c=.o) $(TARGET):$(OBJS) # @echo TARGET:[email protected] # @echo OBJECTS:$^ [tab]$(CC) -o [email protected] $^ clean: [tab]rm -rf $(TARGET) $(OBJS) %.o:%.c [tab]$(CC) $(CFLAGS) -o [email protected] -c $<
【具体说明】
【1】更多说明请参考:例说makefile——单个文件
【2】相对于单个文件,此处仅修改了SRCS=test.c test-add.c test-sub.c,变量SRCS追加了多个C文件。相比单个文件的情况,仅仅修改了这一行。
【3】文件和文件之间通过空格隔开。
【执行过程】
make clean && make
【控制台输出】
rm -rf test test.o test-add.o test-sub.o
gcc -Wall -std=gnu99 -o test.o -c test.c
gcc -Wall -std=gnu99 -o test-add.o -c test-add.c
gcc -Wall -std=gnu99 -o test-sub.o -c test-sub.c
gcc -o test test.o test-add.o test-sub.o
从控制台的输出可以看出,通过make clean清除上一次的可执行文件和目标文件,然后依次编译各个C文件,最后把3个目标文件链接为最终可执行文件。
Linux学习笔记——例说makefile 多个文件