Makefile简单教程

Makefile简单入门

makefile简单教程。

测试程序

sub.c

#include <stdio.h>
int sub_int(int a, int b)
{
    return a - b;
}

add.c

#include <stdio.h>
int add_int(int a, int b)
{
    return a + b;
}

上面是两个简单的.c文件,现在我们编写一个Makefile文件,使得我们在执行make的时候,Makefile能自动的将add.c和sub.c文件编译成.o文件。
Makefile内容:

.PHONY all
all: add.o sub.o
add.o: add.c
    gcc -c add.c -o add.o
sub.o: sub.c
    gcc -c sub.c -o sub.o

注意:makefile中要执行的命令必须以tab开头!!
查看编译结果:我们可以看到makefile已经自动的将add.c和sub.c文件编译成了.o文件。

liujunming@liujunming:~/src/unix/day02/static$ make 
gcc -c add.c -o add.o
gcc -c sub.c -o sub.o
liujunming@liujunming:~/src/unix/day02/static$ lt *.o
-rw-rw-r-- 1 liujunming liujunming 1376 9月  11 10:24 add.o
-rw-rw-r-- 1 liujunming liujunming 1376 9月  11 10:24 sub.o
liujunming@liujunming:~/src/unix/day02/static$ 

规则介绍

Makefile类似shell脚本,当我们执行make的时候,Makefile中的编译规则就会被执行。

依赖和目标

在上文中的makefile中,all、sub.o、add.o他们在冒号的左边,叫目标文件,冒号右边的文件叫依赖文件。举例说明:编译add.o这个目标的时候,需要add.c这个依赖文件,如果add.c更新,则执行make的时候会重新生成add.o文件。

下面添加一个exchange.c文件,去调用add.c和sub.c中的函数,然后将他们打包成静态库:
exchange.c

#include "exchange.h"
void exchange(int *a, int *b)
{
    *a = add_int(*a, *b);
    *b = sub_int(*a, *b);
    *a = sub_int(*a, *b);
}

修改Makefile:

.PHONY: all clean
all: libcalculate.a
libcalculate.a: add.o sub.o exchange.o
    ar -r libcalculate.a add.o sub.o 
add.o: add.c
    gcc -c add.c -o add.o
sub.o: sub.c
    gcc -c sub.c -o sub.o
exchange.o: exchange.c exchange.h
    gcc -c exchange.c -o exchange.o
clean:
    rm -rf *.o *.a

执行make:

liujunming@liujunming:~/src/unix/day02/static$ make
gcc -c add.c -o add.o
gcc -c sub.c -o sub.o
gcc -c exchange.c -o exchange.o
ar -r libcalculate.a add.o sub.o exchange.o
ar: 正在创建 libcalculate.a

查看文件:

liujunming@liujunming:~/src/unix/day02/static$ lt *.o *.a
-rw-rw-r-- 1 liujunming liujunming 1376 9月  11 11:07 add.o
-rw-rw-r-- 1 liujunming liujunming 1376 9月  11 11:07 sub.o
-rw-rw-r-- 1 liujunming liujunming 1720 9月  11 11:07 exchange.o
-rw-rw-r-- 1 liujunming liujunming 4762 9月  11 11:07 libcalculate.a

查看.a文件符号:

伪目标

使用.PHONY 指明伪目标,也就是说.PHONY后面的all和clean并不是我们要生成的目标文件,仅仅会检测依赖。

make执行规则

由于执行make的时候会默认将第一个目标作为最终目标,因此执行make和make all是等价的。

当我们执行make all的时候,1) makefile会检测all这个伪目标后面的依赖文件libcalculate.a是否需要重新编译,2) 而libcalculate.a又依赖add.o,sub.o和exchange.o,三个.o文件也是目标,也会检测他们自己的依赖关系,3) 因此假如我们修改了add.c然后重新make all,那么makefile将会重新编译add.o然后重新创建静态库libcalculate.a
下面我们进行测试:
修改add.c:添加注释//modify
add.c

#include <stdio.h>
//modify
int add_int(int a, int b)
{
    return a + b;
}

执行make编译:

liujunming@liujunming:~/src/unix/day02/static$ make
gcc -c add.c -o add.o
ar -r libcalculate.a add.o sub.o exchange.o

果然和预测的一样呢!

总结:

  1. makefile中应该只有一个最终目标,其它目标被连带。可以手动执行make 目标,来指定编译某个目标。
  2. 伪目标不是一个文件,只是一个标签,需要使用.PHONY指明一个目标是伪目标。
  3. 可以使用伪目标all: 目标1 目标2 目标3 …来实现多目标编译。

第一次写文章,较为简单,大佬们看看就好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值