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)
不太完整有待补充。