Makefile 简单讲解

编译的过程

1、编译流程:

预处理 ->  编译 -> 链接 -> 执行

预处理
clang -E replay.c > replay.i

编译 分为两步:
  1、生成汇编文件
  clang -S replay.i [自动生成replay.s 汇编文件]
  2、根据汇编文件生成目标文件
  clang -c replay.s [自动生成replay.o 目标文件]

链接
clang replay.o -o replay [replay 就是最终的可执行的文件]

执行
./replay 

命令可选项的解释:

//预处理
-E 
// 操作之后输出的文件名字
-o                Write output to 
// 编译生成汇编文件
-S                      Only run preprocess and compilation steps
// 编译成object file (目标文件)
-c  compile 

2、简单的编译命令:

clang replay.c  //生成 a.out
clang replay.c -o replay  //生成 replay可执行文件

3、make 工具
根据时间戳进行判断,是否重新编译。
make clean
声明变量,引用变量是$(var)
CC 是内置变量,表示使用的编译器命令

CFLAGES 是内置变量,表示编译选项
CFLAGES+=-c -Wall -g
OBJS=main.o tool1.o tool2.o
mytool:$(OBJS)
在当前某一行实现上,依赖的文件。可以用下面的符号$^来表示
当前行的目标名,使用$@ 来表示。

第一个版本

OBJS=main.o tool1.o tool2.o //定义变量
CC=gcc #CC是内置变量,一般是指向编译器命令gcc,但是我们可以更改该变量
CFLAGS+=-c -Wall -g #CFLAGS也是内置变量,可以通过+=的方式在不改变默认值的基础上添加自己想要的编译选项

#target:依赖文件
#下面一行是是tab符号开始,表示编译的命令
mytool:$(OBJS)
  $(CC) $^ $(CFLAGS) -o  $@
main.o:main.c
  $(CC) $^ $(CFLAGS) -o $@
tool1.o:tool1.c
  $(CC) $^ $(CFLAGS) -o $@
tool2.o:tool2.c
  $(CC) $^  $(CFLAGS) -o $@

#可以在命令中执行make clean RM= rm -f
clean:
  $(RM) *.o mytool -r

缩减

//提取公式:
XX.o:XX.c
  $(CC) $^ $@
同一句话中%代表同一个名字,%是通配符的概念
OBJS=main.o tool1.o tool2.o #定义变量
CC=gcc #CC是内置变量,一般是指向编译器命令gcc,但是我们可以更改该变量
CFLAGS+=-c -Wall -g #CFLAGS也是内置变量,可以通过+=的方式在不改变默认值的基础上添加自己想要的编译选项

#target:依赖文件
#下面一行是是tab符号开始,表示编译的命令
mytool:$(OBJS)
  $(CC) $^ $(CFLAGS) -o  $@
%.o:%.c
  $(CC) $^ $(CFLAGS) -o $@

#可以在命令中执行make clean RM= rm -f
clean:
  $(RM) *.o mytool -r # *代表文件夹中的所有子文件

% 号讲解:
*代表当前目录下所有,%类似于一个宏是从前一个目标带入时才用的,会用带入的值替换掉%f
makefile讲解

你可能感兴趣的:(Makefile 简单讲解)