澳门正规赌博十大网站-澳门游戏网站
做最好的网站

简易教程,Makefile简单入门教程

一、简介

一 make工具:
利用make工具可以自动完成编译工作。这些工作包括:
如果仅修改了某几个源文件,则指重新编译这几个源文件;如果某个头文件被修改了,则重新编译所有包含该头文件的源文件。利用这种自动编译可大大简化开发工作,避免不必要的重新编译

简易教程,Makefile简单入门教程。在讲述这个Makefile之前,还是让我们先来粗略地看一看Makefile的规则。

make命令执行时,需要一个 Makefile 文件,以告诉make命令需要怎么样的去编译和链接程序(简单将:管理工程的文件,决定先编译哪些文件,编译顺序)。

二 make工具是通过一个称为Makefile的文件来完成并维护编译工作的。Makefile文件描述了整个工程的编译、连接等规则。

target ... : prerequisites ...

二、编写规则:

三 Makefile基本规则
TARGET...:DEPENDENCES...
    COMMAND
    ...
目标(target)程序产生的文件:如可执行文件和目标文件;目标文件也可以是要执行的动作,如clean,也称为伪目标
依赖(DEPENDENCEs)是用来产生目标的输入文件列表。一个目标通常依赖于多个文件。

简易教程,Makefile简单入门教程。简易教程,Makefile简单入门教程。command

目标1:目标依赖  然后回车 tab键
 命令;

命令(COMMAND)是make执行的动作(命令是shell命令或者可在shell下执行的程序)注意:每个命令行的起始字符必须是TAB
如果DEPENDENCES中有一个或多个文件更新,就执行COMMAND命令来更新。

...

目标2:目标依赖  然后回车 tab键
 命令;
...

一个简单的Makefile
.PHONY:clean
main:main.o add.o sub.o
    gcc -Wall -g main.o add.o sub.o -o main
mian.o:mian.c
简易教程,Makefile简单入门教程。    gcc -Wall -g -c main.c -o main.o
add.o:...
    ...
sub.o:...
    ...
clean:
    rm -f main main.o add.o sub.o

...

目标n:目标依赖  然后回车 tab键
 命令;

clean 伪目标不是真正要生成的目标。加上一个.PHONY:clean显示指定clean为伪目标

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

注意:命令必须是tab键开头的。

四:Makefile自动化变量
$@:规则的目标文件名
$<:规则的第一个依赖文件名
$^:规则的所有依赖文件列表

    prerequisites就是,要生成那个target所需要的文件或是目标。

三、Makefile演进
1、一个项目有main.c/a.c/a.h/b.c/b.h五个文件;main.c包含a.h和b.h并使用相关函数;然后建立一个新的Makefile文件,内容如下:
main:a.o b.o
 gcc -o main a.o b.o 
a.o:a.c
 gcc -c a.c -o a.o 
b.o:b.c
 gcc -c b.c -o b.o

.PHONY:clean
OBJECTS=main.o add.o sub.o
main:$(OBJECTS)
    gcc -Wall -g $^ -o $@
mian.o:mian.c
    gcc -Wall -g  -c $< -o $@
add.o:...
    ...
sub.o:...
    ...
clean:
    rm -f main $(OBJECTS)
    
    
再进一步改进
.PHONY:clean
CC=gcc
CFLAGS=-Wall -g
OBJECTS=main.o add.o sub.o
main:$(OBJECTS)
    $(CC) $(CFLAGS) $^ -o $@
mian.o:mian.c
    $(CC) $(CFLAGS) -c $< -o $@
add.o:...
    ...
sub.o:...
    ...
clean:
    rm -f main $(OBJECTS)
    
五、Makefile编译多个可执行文件
.PHONY:clean all   all也是伪目标,要生成all就要生成BIN
CC=gcc
CFLAGS=-Wall -g
BIN:01test 02test
all:$(BIN)
%.o:%.c
    $(CC)  $(CFLAGS) -c $< -o $@
clean:
    rm -f  *.o  $(BIN)

    command也就是make需要执行的命令。(任意的Shell命令)

2、Makefile升级1
采用makefile变量:想用就用,没有类型,不需要定义(引用变量使用$(obj)来包含更多.o文件)
方法:obj:=a.o b.o
那么上面的Makefile程序升级如下:
obj:=a.o b.o
main:$(obj)
 gcc -o main a.o b.o 
a.o:a.c
 gcc -c a.c -o a.o 
b.o:b.c
 gcc -c b.c -o b.o

这是一个文件的依赖关系,也就是说,target这一个或多个的目标文件依赖于prerequisites中的文件,其生成规则定义在command中。说白一点就是说,prerequisites中如果有一个以上的文件比target文件要新的话,command所定义的命令就会被执行。这就是Makefile的规则。也就是Makefile中最核心的内容。

本文由澳门正规赌博十大网站发布于澳门游戏网站,转载请注明出处:简易教程,Makefile简单入门教程