0.前言

所以特意借助博客总结makefile的相关知识。通过样例说明makefile的详细使用方法。

    例说makefile分为下面几个部分。很多其它内容请參考【例说makefile索引博文】

    2.含有多个C文件    

    4.添加宏定义

    5.添加系统共享库

    6.添加自己定义共享库

    7.一个实际的样例


    【代码仓库】——makefile-example

    代码仓库位于bitbucket,可借助TortoiseHg(GUI工具)克隆代码或者在网页中直接下载zip包。

    【本例说明】



1.gcc复习

    宏定义使用前缀-D,在编译过程中能够把宏定义追加到CFLAG中。宏定义有两种相似的写法

    【第一种】-D DEFINES 

    【另外一种】-D DEFINES=CONDITION


2.源文件

    使用两种不同的方式,通过宏定义包裹打印功能,分别使用#ifdef和#if

#include <stdio.h>
#include <test-add.h>
#include <test-sub.h>
int main(void)
{
    int a = 3;
    int b = 2;
       
    printf("a=%d\n", a);
    printf("b=%d\n", b);
#ifdef TEST_ADD
    printf("a+b=%d\n", add(a,b));
#endif
#if TEST_SUB
    printf("a-b=%d\n", sub(a,b));
#endif
    return 0;
}


3.makefile

    请替换当中的[tab],并以代码仓库中的makefile文件为主。

# 指令编译器和选项
CC=gcc
CFLAGS=-Wall -std=gnu99
# 宏定义
DEFS = -DTEST_ADD -DTEST_SUB=1
CFLAGS += $(DEFS)
# 目标文件
    
TARGET=test
# 源文件
SRCS = test.c \
  ./test-add/test-add.c \
  ./test-sub/test-sub.c
# 头文件查找路径
INC = -I./test-add -I./test-sub
# 目标文件
OBJS = $(SRCS:.c=.o)
# 链接为可运行文件
$(TARGET):$(OBJS)
#	@echo TARGET:$@
#	@echo OBJECTS:$^
[tab]$(CC) -o $@ $^
clean:
[tab]rm -rf $(TARGET) $(OBJS)
# 连续动作,请清除再编译链接。最后运行
exec:clean $(TARGET)
[tab]@echo 開始运行
[tab]./$(TARGET)
[tab]@echo 运行结束
# 编译规则 $@代表目标文件 $< 代表第一个依赖文件
%.o:%.c
[tab]$(CC) $(CFLAGS) $(INC) -o $@ -c $<


4.详细说明

    【1】 makefile定义头文件的方法有两种

    【第一种】-D DEFINES 

    【另外一种】-D DEFINES=CONDITION

    当中第一种方法相应

    #ifdef

        do_something()

    #endif

    另外一种方法相应

    #ifndef DEFINES

        do_something()

    #endif

    【2】DEFS = -DTEST_ADD -DTEST_SUB=1 

    为了说明问题。此处使用了两种不同的写法。此时两处打印功能均被运行

    【3】CFLAGS += $(DEFS) 

$(CFLAGS) $(INC) -o $@ -c $< 


5.运行过程

    【编译和链接】

    make clean && make

    【控制台输出】

rm -rf test test.o ./test-add/test-add.o ./test-sub/test-sub.o
gcc -Wall -std=gnu99 -DTEST_ADD -DTEST_SUB=1 -I./test-add -I./test-sub -o test.o -c test.c
gcc -Wall -std=gnu99 -DTEST_ADD -DTEST_SUB=1 -I./test-add -I./test-sub -o test-add/test-add.o -c test-add/test-add.c
gcc -Wall -std=gnu99 -DTEST_ADD -DTEST_SUB=1 -I./test-add -I./test-sub -o test-sub/test-sub.o -c test-sub/test-sub.c
gcc -o test test.o test-add/test-add.o test-sub/test-sub.o

    【运行】

a=3
b=2
a+b=5
a-b=1

    终于效果和预期全然同样,makefile得到的验证。


6.总结

    【1】添加宏两种方法定义 -D DEFINES  和 -D DEFINES=CONDITION

    【2】附加到宏定义CFLAG之后