Linux学习笔记——举例说,makefile 多个文件

0.前言
    从学习C语言開始就慢慢開始接触makefile,查阅了非常多的makefile的资料但总感觉没有真正掌握makefile,假设自己动手写一个makefile总认为非常吃力。

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

    例说makefile分为下面几个部分。很多其它内容请參考【例说makefile索引博文
    1.仅仅有单个C文件   
    2.含有多个C文件    
    3.须要包含头文件路径
    4.添加宏定义
    5.添加系统共享库
    6.添加自己定义共享库
    7.一个实际的样例

    【代码仓库】——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
", a);
    printf("b=%d
", b);
    
    printf("a+b=%d
", add(a,b));
    printf("a-b=%d
", sub(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:$@
#	@echo OBJECTS:$^
[tab]$(CC) -o $@ $^

clean:
[tab]rm -rf $(TARGET) $(OBJS)

%.o:%.c
[tab]$(CC) $(CFLAGS) -o $@ -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个目标文件链接为终于可运行文件。

版权声明:本文博主原创文章,博客,未经同意不得转载。

原文地址:https://www.cnblogs.com/zfyouxi/p/4877095.html