Makefile简介

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Makefile简介相关的知识,希望对你有一定的参考价值。

参考技术A

就像dockerfile之于docker,makefile之于make.....
make命令执行时,需要一个makefile文件,以告诉make命令需要怎么样的去编译和链接程序。
你在命令行敲一个make,会自动去寻找目录下的makefile文件并执行。
可能你在C程序中见到的比较多,但是其实其他语言也是可以用到。

makefile内部是你根据makefile语法规则,自己编写的一条条shell命令等。

target
可以是一个object file(目标文件),也可以是一个执行文件,还可以是一个标签(label)。对于标签这种特性,在后续的“伪目标”章节中会有叙述。

prerequisites
生成该target所依赖的文件和/或target,没有就不需要写

command
该target要执行的命令(任意的shell命令)

下面我们看一个在 golang 中的应用例子

这里执行的任务就是本地编译,把得到的二进制可执行文件用upx压缩之后通过rsync传到服务器,
然后重启服务器的supervisor使程序重启,最后删除本地生成的可执行文件。
这一系列的任务,在makefile编写完成之后,只需要执行一句
make test
就可以完成一系列任务,非常方便。

这里需要注意的几个地方:

.PHONY

.PHONY: build clean tool lint help

其作用是声明 build / clean / tool / lint / help 为伪目标,声明为伪目标会怎么样呢?
声明为伪目标后:在执行对应的命令时,make 就不会去检查是否存在 build / clean / tool / lint / help 其对应的文件,而是每次都会运行标签对应的命令
若不声明:恰好存在对应的文件,则 make 将会认为 xx 文件已存在,没有重新构建的必要了

@

如果你执行 make 会发现,makefile中的每条命令都被打印到shell标准输出中,为什么?

因为make默认就是这么设置的,默认先打印每条命令再执行,这叫 echo

在命令前加@作用就是不让你这条命令打印到标准输出。

Makefile 简介

Makefile/makefile 简介

makefile 规则

target :prerequisites    
command

target: 目标文件
prerequisites: 依赖文件
command: 执行命令
命令执行之前先检查依赖

  • 依赖存在:执行命令
  • 依赖不存在: 向下检测其他的规则,看看是否有一个规则是用来生成这个依赖,如果找到, 执行该规则中的命令

检测更新

  • 在执行规则中的命令的时候, 会比较 目标和依赖文件时间
  • 如果依赖的时间比目标的时间晚,需要重新生成目标
  • 如果依赖的时间比目标的时间早, 目标不需要更新, 对应规则中的命令不需要执行

自动变量

$@: 规则中的目标
$<:规则中的第一个人依赖
$^:规则中的所有依赖 
自动变量只能在规则的命令中使用

模式匹配

a.o:a.c
    gcc -c a.c
b.o:b.c
    gcc -c div.c
    
%.o:%.c
	- %: 通配符, 匹配一个字符串
	- 两个%匹配的是同一个字符串

以上的代码可以替换成:
%.o:%.c
	gcc -c $< -o $@

一个简单的makefile

https://www.gnu.org/software/make/manual/html_node/Simple-Makefile.html

edit : main.o kbd.o command.o display.o        insert.o search.o files.o utils.o
        cc -o edit main.o kbd.o command.o display.o                    insert.o search.o files.o utils.o

main.o : main.c defs.h
        cc -c main.c
kbd.o : kbd.c defs.h command.h
        cc -c kbd.c
command.o : command.c defs.h command.h
        cc -c command.c
display.o : display.c defs.h buffer.h
        cc -c display.c
insert.o : insert.c defs.h buffer.h
        cc -c insert.c
search.o : search.c defs.h buffer.h
        cc -c search.c
files.o : files.c defs.h buffer.h command.h
        cc -c files.c
utils.o : utils.c defs.h
        cc -c utils.c
clean :
        rm edit main.o kbd.o command.o display.o            insert.o search.o files.o utils.o

以上是关于Makefile简介的主要内容,如果未能解决你的问题,请参考以下文章

1-Makefile简介

Makefile 简介

Makefile编写

Linux操作系统自动化编译make和Makefile

简介make命令和makefile文件

Makefile