linux之Makefile 编写、规则、伪目标

什么是Makefile?首先,make是一个工具程序(Utility software),是一种控制编译或者重复编译软件的工具;make可以自动管理软件编译的内容、方式和时机从而使程序员能够把精力集中在编写代码上。那make怎样工作呢?其实make是通过makefile文件实现的。makefile是一个文本形式的数据库文件。其中包含一些规则,这些规则告诉make需要编译哪些文件、怎样编译这些文件以及在什么样的条件下去编译。

关于Makefile的基本规则:

target: dependency [dependency [...]]
           command
           command
           [...]
每个命令的第一个字符必须是制表符,使用空格代替是不正确的。

其中,target是需要创建的二进制文件或目标文件,虽然目标体通常是程序,但它们也可以是文本文件、手册页面等任何东西甚至可以被用作测试和设置环境变量。dependency是在创建target时需要输入的一个或者是多个文件的列表。命令序列是创建target文件所需的步骤,如编译命令。一般,没有特殊指定的情况下,make的工作目录就是当前的目录。当GNU make被调用时会顺序查找名为GNUmakefile、makefile或者是Makefile的文件,但不知出于于某种不可描述的原因,绝大部分的Linux程序员习惯性的使用 Makefile这种形式。

简单的makefile写法:

 首先有这么几个简单的程序 howdy.c helper.h helper.c

 howdy.c

#include<stdio.h>
#include"helper.h"
int main()
{
        printf("hello,linux programming world\n");
        msg();
        return 0;
}

头文件 helper.h

void msg(void);

helper.c

#include<stdio.h>
void msg(void)
{
        printf("This message sent form helper.c .\n");
}

 好了,利用上述的这些程序写一个简单的Makefile文件

    

howdy:howdy.o helper.o helper.h
        gcc howdy.o helper.o -o howdy
helper.o:helper.c helper.h
        gcc -c helper.c
howdy.o:howdy.c
        gcc -c howdy.c
clean:
        rm howdy *.o

要编译howdy,只要在Makefile目录下键入make即可。第一个目标体howdy称为默认(default)目标体--这就是该Makefile文件要创建的文件。howdy有三个依赖体,分别为howdy.o helper.o helper.h;要生成howdy这个文件就必须要他所依赖的这三个文件。第二行就是调用编译器的命令来供make执行来创建howdy文件,其中helper.h也列入依赖体的原因是为了防止编译器调用未申明的函数产生错误。接下来的规则是告诉make怎样生成单个目标文件:helper.o和howdy.o。这两个规则用了gcc -c选项,其含义为只编译但不链接文件。

嗯,,,大概的编译链接过程就是上图这样,howdy.c和helper.c这两个源文件经过预处理后编译成目标文件,然后连接器把来自howdy.o和helper.o的目标代码以及标准库和c启动代码链接到一起生成可执行的二进制文件howdy。通常情况下,如果在依赖体helper.o和howdy.o不存在的情况下使用命令编译howdy,那么gcc会报错并退出。On the other hand,编译器在看到howdy需要这两个文件(以及helper.h)后,make先看它们是否存在,如果不存在则根据规则命令生成它们,然后再根据第一条规则生成howdy。显然地,如果helper.h不存在,也会报错退出,因为Makefile文件中并没有规则命令生成helper.h。

好了,大概明白make是怎么执行的了,那新的问题又来了,make怎么知道什么时候该重新编译一个新的文件呢?  其实很简单:如果指定的目标文件不存在,那么毫无疑问,make就会根据规则命令生成它;如果目标文件已经存在,那么make就会将目标文件和依赖文件的时间戳进行对比,如果有一个以上的依赖文件比目标文件新(就是依赖文件的修改时间比目标文件的时间新),那么make就会重新编译生成新的目标体。

伪目标:

什么是伪目标?伪目标就是上面Makefile文件的clean就是伪目标,伪目标就是不对应实际的文件。但是,由于伪目标没有依赖体,所以它的命令是不会自动被make执行的,如果要编译执行这个目标体,那么只需 make clean,编译器就会编译执行clean的命令。但是,如果刚好有个名字叫做clean的文件存在,那么make就会发现它,但是clean没有依赖体,所以make就会认为clean已经是最新的文件从而不会执行其命令。为了处理这种情况,就需要使用特殊的目标体.PHONY。.PHONY的依赖体文件的含义和通常的一样,但是make不检查是否存在有文件名和依赖体中的一个名字相匹配的文件,而是直接执行与之相关的命令。如果使用.PHONY,上述的Makefile文件就成了下面这样

howdy:howdy.o helper.o helper.h
        gcc howdy.o helper.o -o howdy
helper.o:helper.c helper.h
        gcc -c helper.c
howdy.o:howdy.c
        gcc -c howdy.c
#hello:hello.c
#       gcc hello.c -o hello
#all:howdy hello
.PHONY
clean:
        rm howdy *.o

什么意思?一句话,意思就是:make在更新目标文件时,不管clean后面有没有依赖,都会直接执行clean下面的命令。

原文地址:https://www.cnblogs.com/sugarxt/p/10585865.html

时间: 2024-10-03 06:17:23

linux之Makefile 编写、规则、伪目标的相关文章

linux下makefile编写及automake整理

makefile编写规则 在一个makefile中通常包含如下内容: 1 需要由make工具创建的目标体(target),通常是目标文件或可执行文件 2 要创建的目标体所依赖的文件(dependency_file) 3 创建每个目标体时需要运行的命令(command),这一行必须以制表符(tab键)开头 格式: target: dependency_files command /* 该行必须以tab键开头*/ 例如,有两个文件分别为hello.c和hello.h,创建的目标体为hello.o,执

浅谈Linux下Makefile编写

浅谈Linux下Makefile的编写 前言:本文简要介绍Makefile文件的编写规范,结合具体项目中的应用进行讲解. 具体代码地址: https://github.com/AnSwErYWJ/DogFood/blob/master/Makefile 简介 Make工具最主要也是最基本的功能就是通过makefile文件来描述源程序之间的相互关系并自动维护编译工作.而makefile 文件需要按照某种语法进行编写,文件中需要说明如何编译各个源文件并连接生成可执行文件,并要求定义源文件之间的依赖关

makefile中的伪目标

伪目标就是总是被执行的目标,相对于目标来说,伪目标不会去考虑它的依赖的时间戳与自己时间戳的新旧关系,从而决定是否执行规则.伪目标格式: .PHONY:clean clean: -rm *.o 在makefile里面通常会将clean这个目标指定为伪目标,这个目标有个特性就是无依赖,那么每次make clean的时候都会执行它的规则:-rm *.o,那么为什么要指定为伪目标,平时看到的makefile都是把它当中一般目标.假设不指定clean为伪目标,我当前文件夹下有1个文件: a.c.我的mak

.PHONY makefile中的伪目标

我的理解: 拿clean举例,如果make完成后,自己另外定义一个名叫clean的文件,再执行make clean时,将不会执行rm命令. 为了避免出现这个问题,需要.PHONY: clean ======================================================================================= 所谓伪目标就是这样一个目标,它不代表一个真正的文件名,在执行make时可以指定这个目标来执行其所在规则定义的命令,有时我们将一个伪

makefile编写规则

cc = g++ -std=c++11 prom = calc deps = FtTest.h obj = FtTest.o newft.o LIBS = -lgtest_c11 $(prom): $(obj) $(cc) -o $(prom) $(obj) $(LIBS) %.o: %.c $(deps) $(cc) -c $< -o [email protected] 原文地址:https://www.cnblogs.com/ims-/p/9862557.html

第3课 - makefile伪目标的引入

第3课 - makefile伪目标的引入 1. makefile中的目标究竟是什么? (1)默认情况下,make认为目标对应着一个文件 →  目标即文件名 (2)make首先会检测目标对应的文件是否存在,若不存在则执行依赖和命令.若存在则会比较目标文件和依赖文件的新旧关系,决定是否执行命令. (3)make以文件处理作为第一优先级 2. 伪目标的引入 下面的代码有什么意义? clean : rm *.o hello.out ↓ make clean 执行make clean会将第2课中编译生成的

Makefile伪目标

本节我们讨论一个Makefile中的一个重要的特殊目标:伪目标. 伪目标是这样一个目标:它不代表一个真正的文件名,在执行make时可以指定这个目标来执行其所在规则定义的命令,有时我们也可以将一个伪目标称为标签.使用伪目标有两点原因: 1. 避免在我们的Makefile中定义的只执行命令的的目标(此目标的目的为了执行执行一系列命令,而不需要创建这个目标)和工作目录下的实际文件出现名字冲突. 2. 提高执行make时的效率,特别是对于一个大型的工程来说,编译的效率也许你同样关心. 以下就这两个问题我

makefile编写--引用

1. Makefile 简介 Makefile 是和 make 命令一起配合使用的. 很多大型项目的编译都是通过 Makefile 来组织的, 如果没有 Makefile, 那很多项目中各种库和代码之间的依赖关系不知会多复杂. Makefile的组织流程的能力如此之强, 不仅可以用来编译项目, 还可以用来组织我们平时的一些日常操作. 这个需要大家发挥自己的想象力. 本篇博客是基于 {精华} 跟我一起写 Makefile 而整理的, 有些删减, 追加了一些示例. 非常感谢 gunguymadman

Linux内核Makefile笔记

周亦行 2014年11月 参考文档 ① linux源码Makefile的详细分析 ② if_changed_rule/cc_o_c/any-prereq/arg-check ③ Makefile中的伪目标 ④ Linux kernel 3.18.5 一.Makefile组成 (一)基本组成 顶层 Makefile 它是所有Makefile文件的核心,从总体上控制着内核的编译.连接 arch/$(ARCH)/Makefile 对应体系结构的Makefile,它用来决定哪些体系结构相关的文件参与内核