`

makefile文件的编写

阅读更多
1.源程序的编译

在Linux下面,如果要编译一个C语言源程序,我们要使用GNU的gcc编译器. 下面我们以一个实例来说明如何使用gcc编译器.

假设我们有下面一个非常简单的源程序(hello.c):


int main(int argc,char **argv)
{
printf(""Hello Linux "");
}


要编译这个程序,我们只要在命令行下执行:

gcc -o hello hello.c

gcc 编译器就会为我们生成一个hello的可执行文件.执行./hello就可以看到程序的输出结果了.命令行中 gcc表示我们是用gcc来编译我们的源程序,-o 选项表示我们要求编译器给我们输出的可执行文件名为hello 而hello.c是我们的源程序文件.

gcc编译器有许多选项,一般来说我们只要知道其中的几个就够了. -o选项我们已经知道了,表示我们要求输出的可执行文件名. -c选项表示我们只要求编译器输出目标代码,而不必要输出可执行文件. -g选项表示我们要求编译器在编译的时候提供我们以后对程序进行调试的信息.

知道了这三个选项,我们就可以编译我们自己所写的简单的源程序了,如果你想要知道更多的选项,可以查看gcc的帮助文档,那里有着许多对其它选项的详细说明.

2.Makefile的编写

假设我们有下面这样的一个程序,源代码如下:


/* main.c */
#include ""mytool1.h""
#include ""mytool2.h""
int main(int argc,char **argv)
{
mytool1_print(""hello"");
mytool2_print(""hello"");
}
/* mytool1.h */
#ifndef _MYTOOL_1_H
#define _MYTOOL_1_H
void mytool1_print(char *print_str);
#endif
/* mytool1.c */
#include ""mytool1.h""
void mytool1_print(char *print_str)
{
printf(""This is mytool1 print %s "",print_str);
}
/* mytool2.h */
#ifndef _MYTOOL_2_H
#define _MYTOOL_2_H
void mytool2_print(char *print_str);
#endif
/* mytool2.c */
#include ""mytool2.h""
void mytool2_print(char *print_str)
{
printf(""This is mytool2 print %s "",print_str);
}


当然由于这个程序是很短的我们可以这样来编译

gcc -c main.c

gcc -c mytool1.c

gcc -c mytool2.c

gcc -o main main.o mytool1.o mytool2.o

这样的话我们也可以产生main程序,而且也不时很麻烦.但是如果我们考虑一下如果有一天我们修改了其中的一个文件(比如说mytool1.c)那么我们难道还要重新输入上面的命令?也许你会说,这个很容易解决啊,我写一个SHELL脚本,让她帮我去完成不就可以了.是的对于这个程序来说,是可以起到作用的.但是当我们把事情想的更复杂一点,如果我们的程序有几百个源程序的时候,难道也要编译器重新一个一个的去编译?

为此,聪明的程序员们想出了一个很好的工具来做这件事情,这就是make.我们只要执行以下make,就可以把上面的问题解决掉.在我们执行make之前,我们要先编写一个非常重要的文件.Makefile.对于上面的那个程序来说,可能的一个Makefile的文件是:

# 这是上面那个程序的Makefile文件

main:main.o mytool1.o mytool2.o

gcc -o main main.o mytool1.o mytool2.o

main.o:main.c mytool1.h mytool2.h

gcc -c main.c

mytool1.o:mytool1.c mytool1.h

gcc -c mytool1.c

mytool2.o:mytool2.c mytool2.h

gcc -c mytool2.c

有了这个Makefile文件,不过我们什么时候修改了源程序当中的什么文件,我们只要执行make命令,我们的编译器都只会去编译和我们修改的文件有关的文件,其它的文件她连理都不想去理的.

下面我们学习Makefile是如何编写的.

在Makefile中也#开始的行都是注释行.Makefile中最重要的是描述文件的依赖关系的说明.一般的格式是:

target: components

TAB rule

第一行表示的是依赖关系.第二行是规则.

比如说我们上面的那个Makefile文件的第二行

main:main.o mytool1.o mytool2.o

表示我们的目标(target)main的依赖对象(components)是main.o mytool1.o mytool2.o 当倚赖的对象在目标修改后修改的话,就要去执行规则一行所指定的命令.就象我们的上面那个Makefile第三行所说的一样要执行 gcc -o main main.o mytool1.o mytool2.o 注意规则一行中的TAB表示那里是一个TAB键

Makefile有三个非常有用的变量.分别是$@,$^,$ <代表的意义分别是:

$@目标文件,$^所有的依赖文件,$ <第一个依赖文件.

如果我们使用上面三个变量,那么我们可以简化我们的Makefile文件为:

# 这是简化后的Makefile

main:main.o mytool1.o mytool2.o

gcc -o $@ $^

main.o:main.c mytool1.h mytool2.h

gcc -c $ <

mytool1.o:mytool1.c mytool1.h

gcc -c $ <

mytool2.o:mytool2.c mytool2.h

gcc -c $ <

经过简化后我们的Makefile是简单了一点,不过人们有时候还想简单一点.这里我们学习一个Makefile的缺省规则

.c.o:

gcc -c $ <

这个规则表示所有的 .o文件都是依赖与相应的.c文件的.例如mytool.o依赖于mytool.c这样Makefile还可以变为:

# 这是再一次简化后的Makefile

main:main.o mytool1.o mytool2.o

gcc -o $@ $^

.c.o:

gcc -c $ <

好了,我们的Makefile 也差不多了,如果想知道更多的关于Makefile规则可以查看相应的文档.
分享到:
评论

相关推荐

    linux下makefile文件编写详细步骤

    ### Linux下Makefile文件编写详细步骤 #### 一、Makefile简介 Makefile是用于自动化构建过程的一种脚本文件,在Linux环境下广泛应用于软件项目管理、编译和链接等多个环节。通过定义一系列规则来指定如何编译和...

    Makefile文件编写指南针

    【Makefile文件编写指南】 Makefile 是在Unix和类Unix系统中用于自动化构建软件的文本文件,它定义了项目的编译规则和依赖关系。对于一个专业的程序员,掌握Makefile的编写至关重要,因为它能够显著提高软件开发...

    Qt中的Makefile文件编写体会.docx

    总结来说,Qt中的Makefile文件编写涉及到以下几个关键知识点: 1. Makefile基本结构:目标、依赖项和命令。 2. 手动编写Makefile:需要指定编译规则、链接选项、库依赖等。 3. 使用qmake:通过Qt的元编译器简化...

    source文件和makefile文件编写

    source文件和makefile文件编写  1. 编译时必须保证 makefile,sources和源程序在同一目录下 2. 编写sources文件时,其中的"="两边不能有空格 3. 工程的工作目录的绝对路径中不能出现空格,而且表面上看来DDK好像是...

    Makefile文件编写详解

    利用makefile工具可以自动完成编译工作。如果仅修改了几个源文件,则只重新编译这几个源文件,其他没有修改的不再去编译。如果某个头文件被修改,则只重新编译包含这几个头文件的源文件。因此可以简化开发工作。

    Linux下Makefile文件的编写

    ### Linux下Makefile文件的编写 #### Makefile文件的基本概念与作用 Makefile是一种用于自动化构建过程的脚本文件,在Linux环境下广泛应用于软件项目的编译、链接等操作中。通过定义一系列规则,Makefile能够自动...

    简单的makefile文件编写

    用于学习makefile编写支持vcs

    makefile文件编写

    接触linux和unix难免会用到makefile文件,这篇文章详细介绍了makefile文件的编写规则,能够使你在短时间内熟悉makefile的编写,进而写出自己所需的且十分规范的makefile文件。

    LINUX C++下多个Makefile编写方法

    在这个主题中,我们将深入探讨如何在C++项目中编写和管理多个Makefile,以便于更有效地组织代码和构建过程。 首先,我们要理解一个主Makefile(通常命名为`Makefile`)的角色。主Makefile是整个项目的入口,它负责...

    makefile 文件编写

    以下是关于`Makefile`文件编写的一些关键知识点: 1. **目标与依赖**:`Makefile`中的每一行通常表示一个目标(通常是文件),后面跟着一个或多个依赖项。目标是需要生成或更新的文件,依赖项是生成目标所需的文件...

    Makefile文件编写

    本文将深入讲解 `Makefile` 的编写规则,旨在为初学者提供通俗易懂的指南。 1. **概述** `Makefile` 是一个文本文件,包含了执行一系列命令的规则,这些命令通常用于编译、链接源代码。`Make` 使用 `Makefile` 来...

    Makefile 的编写指导

    ### Makefile 的编写指导 #### 概述 Makefile 是一种用于自动化编译流程的脚本文件,在 Unix 和类 Unix 系统中广泛使用。它不仅适用于 C/C++ 项目,也适用于其他语言项目的编译过程。对于大型项目而言,合理地组织...

    makefile详解中文版-详细描写makefile语法

    Makefile 文件的编写需要考虑到项目的构建过程和依赖关系。 GNU Make 使用手册 GNU Make 使用手册是 Make 工具的官方文档,提供了详细的使用指南和参考手册。手册中包含了 Make 工具的所有功能和参数,能够帮助...

    GNUmake-Makefile文件

    * Makefile 文件编写困难:Makefile 文件的编写需要一定的经验和知识,否则可能会出现错误。 GNU Make 是一个功能强大且灵活的 Make 工具,广泛应用于软件开发、编译和生成可执行文件的过程中。

    Linux平台Makefile文件的编写基础篇

    ### Linux平台Makefile文件的编写基础篇 #### 知识点概述 本篇文章将围绕Linux平台下Makefile文件的基础编写技巧展开,旨在帮助读者更好地理解并掌握如何利用Makefile进行C语言程序的编译管理。Makefile作为一种...

    GNU MakeFile使用手册.pdf

    - 警示了在Makefile文件编写过程中需要注意的安全事项。 以上是对《GNU Make使用手册》内容的概览总结,涵盖了makefile的基础概念、编写方法以及高级应用等各个方面,旨在帮助读者全面理解和掌握makefile的相关...

    Makefile的编写指导.pdf

    ### Makefile的编写指导 #### 概述 Makefile 是一种用于自动化编译流程的脚本文件,在 Unix 和类 Unix 系统中广泛使用。它能够显著提高软件开发的效率,尤其是在处理大型工程项目时,通过定义一系列规则来指定...

    makefile实验报告和代码.rar

    The final product is an executable file named sinewave, which is created by linking together two other compiled files, sinewave.o and intarray.o. The two compiled files were created by compiling sine...

    多个文件编写makefile

    `Makefile`的基本结构由一系列规则组成,每个规则定义了一个目标文件(通常是编译后的`.o`对象文件或最终的可执行文件)以及生成该目标文件所需要的依赖文件。例如,如果一个项目有`main.c`、`func1.c`和`func2.c`三...

Global site tag (gtag.js) - Google Analytics