一个Makefile例子

main.c:

#include "log.h"
int main()
{
	sum();
	sub();
	dev();
	mul();
	return 0;
}

sum.c

#include "log.h"
void sum()
{
	printf("a + b = %d\n",a + b);
}

sub.c

#include "log.h"
void sub()
{
	printf("a - b = %d\n",a - b);
}

dev.c

#include "log.h"
void sub()
{
	printf("a / b = %d\n",a / b);
}

mul.c

#include "log.h"
void sub()
{
	printf("a * b = %d\n",a * b);
}

log.h

#include <stdio.h>
static int a = 10;
static int b = 10;
void sum();
void dev();
void mul();
void sub();

创建文本文档makefile
显示规则:
目标文件:依赖文件
【tab】指令
第一个目标文件就是最终文件

result : main.o sum.o sub.o dev.o mul.o
	gcc -o result main.o sum.o sub.o dev.o mul.o
main.o : main.c log.h
	gcc -c main.c
sum.o : sum.c log.h
	gcc -c sum.c
sub.o :sub.c log.h
	gcc -c sub.c
dev.o : dev.c log.h
	gcc -c dev.c
mul.o : mul.c log.h
	gcc -c mul.c
.PHONY:clean
	clean:
		rm result main.o sum.o sub.o dev.o mul.o

2.引入变量,使makefile更简洁
把重复的,比较长的都换成变量
=替换 +=追加 :=恒等于
使用变量的方法 $(变量名)
从上面可以看到每一个.o文件都有log.h,所以就写在一起

objects = main.o sum.o sub.o dev.o mul.o
CC = gcc
TAR = result

$(TAR) : $(objects)
	$(CC) -o $(TAR) $(objects)
$(objects) : log.h
main.o : main.c
sum.o : sum.c
sub.o : sub.c
dev.o : dev.c
mul.o : mul.c
.PHONY:clean
clean:
		rm $(TAR) $(objects)

3.隐含规则和引入通配符
%.c:任意.c文件
%.o:任意.o文件
*.c:所有.c文件
*.o:所有.o文件
$^:所有依赖文件
$@:所有目标文件
@<:所有依赖文件的第一个文件

objects = main.o sum.o sub.o dev.o mul.o
CC = gcc
TAR = result
$(TAR) : $(objects)
	$(CC) -o $@ $^
$(objects) : log.h
	%.o : %.c
.PHONY:clean
clean:
      	rm $(TAR) $(objects)

不太完整有待补充。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值