zoukankan      html  css  js  c++  java
  • Makefile学习(一)[第二版]

    简介

    1)make:利用 make 工具可以自动完成编译工作。这些工作包括:如果仅修改了某几个源文件,则只重新编译这几个源文件[make通过比对相应的.c文件与.o文件的时间];如果某个头文件被修改了,则重新编译所有包含该头文件的源文件。利用这种自动编译可大大简化开发工作,避免不必要的重新编译。

    2)Mackfile:make工具通过一个称为 Mackfile 的文件来完成并自动维护编译工作。Mackfile文件描述了整个工程的编译、连接等规则

     

    Mackfile基本规则

    Target ...: Dependencies ...

    Command ...

     

    说明:

    1)目标(TARGET):即最终想要产生的文件,如:可执行文件,目标文件或中间文件等;目标也可以是要执行的动作,如clean,也称为伪目标。

    2)依赖(DEPENDENCIES):为了产生目标文件而依赖的文件列表,一个目标通常依赖于多个文件。

    3)命令(COMMAND):是make执行的动作(shell命令或是可在shell下执行的程序,如echo)。注意:每个命令行的起始字符必须为TAB字符

    如果DEPENDENCIES中有一个或多个文件更新的话,COMMAND就要执行,这就是Makefile最核心的内容.

     

    简单的Mackfile示例

     

    #1 最简单

    hello:

    gcc -o hello hello.c

     

    #2 稍微复杂

    hello:hello.o

    gcc -o hello hello.o

     

    hello.o:

    gcc -o hello.o -c hello.c

     

    #3 进一步完善

    hello:hello.o

    gcc -o hello hello.o

     

    hello.o:

    gcc -o hello.o -c hello.c

     

    clean:

    rm -rf hello.o  #delete file hello.o

     

    #4 在Mackfile中执行shell命令[@符号:不输出命令本身]

    hello:hello.o

    gcc -o hello hello.o

    @echo "--------------ok------------"

     

    hello.o:

    gcc -o hello.o -c hello.c

     

    clean:

    rm -rf hello.o  #delete file hello.o

     

    #5 综合[.PHONY:#显示声明伪目标]

    .PHONY: clean

    main: main.o sub.o add.o

    gcc -Wall -g -o main main.o sub.o add.o

     

    main.o: main.c

    gcc -Wall -g -o main.o -c main.c

     

    add.o: add.c add.h

    gcc -Wall -g -o add.o -c add.c

     

    sub.o: sub.c sub.h

    gcc -Wall -g -o sub.o -c sub.c

     

    clean:

    rm -f main.o sub.o add.o

     

    执行:

    1)make #生成第一个目标

    2)make clean #“生成”clean伪目标

    3)make main.o #仅生成main.o目标

    4)make -f Mackfile #显示指定执行的文件名

     

    Makefile变量

    为了简化和维护Mackfile,可以在Mackfile中使用变量,格式

    varname=some_text

    引用变量的值:$(varname)

    按照惯例,在Mackfile中,变量一般大写

     

     

    Makefile自动化变量

    选项名

    作用

    $@

    规则的目标文件名

    $<

    规则的第一个依赖文件名

    $^

    规则的所有依赖文列表

    $*

    不包括后缀名的当前依赖文件名

    $?

    当前目标所依赖的文件列表中比当前目标文件还要新的文件

     

     

    #综合示例

    .PHONY: clean

    .SUFFIXES: .c .o

    .c.o:

        gcc -Wall -g -o $@ -c $^

     

    OBJECTS = main.o sub.o add.o

    SOURCES = $(OBJECTS:.o=.c)

     

    main: $(OBJECTS)

        gcc -Wall -g -o $@ $^

     

    clean:

        @echo "delete execute file and object file..."

        rm -f $(OBJECTS) main

     

    附-

    .SUFFIXES:.c .o #表示任何x.c文件与x.o文件关联

     

    Make使用隐含推导规则/生成多个可执行文件

    #示例-生成多个可执行文件1

    .PHONY: clean all 

     

    BIN = 01test 02test

     

    all: $(BIN)

     

    clean:

        -rm -f $(BIN)

     

    #示例-生成多个可执行文件2-使用自己定制的规则,生成.o中间文件

    .PHONY: clean all 

     

    BIN = 01test 02test

    OBJECTS = $(BIN:=.o)

     

    all: $(BIN)

     

    01test.o: 01test.c

    02test.o: 02test.c

     

    clean:

    -rm -f $(BIN) $(OBJECTS)

     

    #示例-生成多个可执行文件3-使用更加细致的规则

    .PHONY: clean all 

        

    CFLAGS = -g -Wall

    CC = gcc 

     

    BIN = 01test 02test

    OBJECTS = $(BIN:=.o)

     

    .SUFFIXES: .c .o

    .c.o:

        $(CC) $(CFLAGS) -c $< -o $@

     

    all: $(BIN)

     

    01test.o: 01test.c

    02test.o: 02test.c

     

    clean:

        -rm -f $(BIN) $(OBJECTS)

     

    模式规则与后缀规则

    %.o:%.c

    .c.o:

     

    #示例

    .PHONY: clean all 

     

    CC = gcc 

    CFLAGS = -Wall -g

    BIN = 01test 02test 

    SOURCES = $(BIN:=.c)

    OBJECTS = $(BIN:=.o)

     

    all: $(BIN)

     

    01test: 01test.o

    02test: 02test.o

     

    #%.o: %.c #模式规则

    #   $(CC) $(CFLAGS) -c $< -o $@

    .c.o: #后缀规则,与前作用相同

        $(CC) $(CFLAGS) -c $< -o $@

     

    clean:

        -rm -rf $(BIN) $(OBJECTS) 


  • 相关阅读:
    浅谈Huffman树
    CF884D:Boxes And Balls
    MySQL单表查询(重要)
    MySQL字段完整性约束(重要)
    MySQL数据类型(重要)
    数据库基本操作
    MySQL权限管理
    MySQL存储引擎概述
    数据库基础
    并发编程小结
  • 原文地址:https://www.cnblogs.com/itrena/p/5927015.html
Copyright © 2011-2022 走看看