美文网首页
Makefile 简单讲解

Makefile 简单讲解

作者: 学习路上一个远行者 | 来源:发表于2020-03-08 21:23 被阅读0次

编译的过程

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 <file>               Write output to <file>
// 编译生成汇编文件
-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 简单讲解

    编译的过程 1、编译流程: 命令可选项的解释: 2、简单的编译命令: 3、make 工具根据时间戳进行判断,是否重...

  • C之make,Makefile

    跟我一起写 Makefile(一) - CSDN博客,结合YOLOv3下面的Makefile讲解看 makefil...

  • Makefile 学习

    Makefile 一、Makefile 简单使用 Makefile是Linux系统下的一种编译脚本,更快、更方便的...

  • Makefile基础

    介绍 Wikipedia上的 Makefile介绍。简单来说:  Makefile就是告诉gcc/g++如何编译项...

  • Makefile笔记

    Makefile 笔记 一、简单的 Makefile 例子 文档目录结构文档目录结构是用户目录HOME下有src ...

  • 《GNU Autoconf》基础2017.4.24-4.25

    第二章 如何运行configure以及Makefile标准 2.1 configuring 讲解了./config...

  • cmake快速实战

    目录 cmake快速实战 Android JNI基础知识讲解 Android JNI实战 makefile前言 我...

  • Makefile

    1.makefile 简单模板: 2.make

  • makefile简单使用

    Makefile规则 一句话总结就是依赖关系,简单如下所示 target … : prerequisites … ...

  • Makefile简单学习

    这是 自己动手写CPU 中的一个Makefile代码, 借助这个代码来初学Makefile的基本组成. 这段就是对...

网友评论

      本文标题:Makefile 简单讲解

      本文链接:https://www.haomeiwen.com/subject/sszjdhtx.html