参考: 跟我一起写 Makefile

GNU make

《GNU+Make项目管理(第三版)》

1.Makefile用途

使用GNU Make工具来管理程序是每个Linux工程师必须掌握的技能。Make能够使整个程序的编译、链接只需要一个命令(make)就可以完成。

Make的工作主要依赖于一个叫为Makefile的文件。Makefile文件描述了整个程序的编译,连接等规则。其中包括:工程中的哪些源文件需要编译以及如何编译,如何最后产生我们想要得可执行文件。

2.Makefile构成

2.1 Makefile构成-规则

Makefile中最重要的组成部分是“规则”

规则:用于说明如何生成目标文件,规则的格式如下:

targets : prerequisites

               command

目标 依赖

[Tab] 命令(可以有多条)

特别注意:命令行前需要使用【TAB】键空格,一条规则里目标只有一个,依赖和命令可以有多个

例子:

led.elf: led.o

    arm-linux-ld -Tled.lds -o led.elf led.o

 

2.2 Makefile构成-伪目标

Makefile中把那些只包含命令,没有任何依赖目标称为伪目标(phony targets).

.PHONY : clean

clean :

    rm f hello main.o func.o

.PHONYclean目标声明为伪目标

 

2.3 Makefile构成-最终目标

1.当一个makefile中有多条规则时,如何单独执行某条规则?

   make + 你想得到的目标,make默认执行第一条规则

     

2. 如果用户没有指定执行某一条规则,直接运行make命令会默认执行makefile中的1条规则,而这条规则中的目标称之为:最终目标

clean通常是用来清除一些我们产生的中间文件:

2.4 Makefile规则-变量 (简化Makefile)

使用变量前:

app1: app1.o func1.o func2.o

    gcc app1.o func1.o func2.o -o app1

app2: app2.o func1.o func2.o

    gcc app2.o func1.o func2.o -o app2

使用变量后:

obj=func1.o func2.o (变量赋值没有空格)

app1: app1.o $(obj) (引用变量:$(obj)

    gcc app1.o $(obj) -o app1

app2: app2.o $(obj)

    gcc app2.o $(obj) -o app2

注:在一个Makefile中多出出现的组成部分,可以使用变量来替换;在Makefile中变量是没有类型的。

makefile中,用户除了可以自己定义变量外,还可以直接使用系统已经定义好的默认变量:

$<:代表第一个依赖文件

    $^代表所有的依赖文件

$@:代表目标集合

% :模式匹配符(%.o表示当前目录下的所有.o文件)

使用前:

led.o : led.S

    arm-linux-gcc -g o led.o -c led.S

使用后:

led.o : led.S

    arm-linux-gcc -g o $@ -c $^

 

2.5 Makefile构成-通用规则

当一个makefile中有许多类似的规则时,如何将这些规则合并为一条通用规则?

目标的名字依赖的名字仅仅是后缀不一样,如下图:

我们可以用%修改;%表示任意的名字

注:Makefile中“#字符后的内容被视作注释。

 

3.Makefile使用技巧

3.1 使用技巧-使用伪目标指令烧写程序到sd卡

3.2 使用技巧-去回显(在编译大源代码的时候非常有用,回显占用编译时间)

hello: hello.c

    @gcc hello.c o hello

在命令前面加@:取消回显

3.3 使用技巧-文件名

make命令默认在当前目录下寻找名字为makefile或者Makefile的工程文件,当名字不为这两者之一时,可以使用如下方法指定:make f 文件名

Makefile — 基础的更多相关文章

  1. Makefile基础---编译

    首先写一个自己的库: #include "../MyAPI.h" #include <cstdlib> #include <ctime> int getRa ...

  2. Makefile基础学习

    Makefile基础学习 理论知识 makefile关系到了整个工程的编译规则.一个工程中的源文件不计其数,并且按类型.功能.模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文 ...

  3. Makefile基础(三)

    第一章:C语言之Makefile基础(一) 第二章:C语言之Makefile基础(二) 再来看一个简单的例子: [root@localhost linux_c]# cat Makefile foo = ...

  4. Makefile基础(二)

    上一章:C语言之Makefile基础(一) 上一章的Makefile写的中规中矩,比较繁琐,是为了讲清楚基本概念,其实Makefile有很多灵活的写法,可以写的更简洁,同时减少出错的可能 一个目标依赖 ...

  5. Linux学习二:Makefile基础

    文首感谢http://www.chinaunix.net 作者:gunguymadman的分享 makefile关系到了整个工程的编译规则.一个工程中的源文件不计数,其按类型.功能.模块分别放在若干个 ...

  6. 5、Makefile基础知识汇总(转自陈皓总述)

    一.Makefile里有什么? Makefile里主要包含了五个东西:显式规则.隐晦规则.变量定义.文件指示和注释. 1.显式规则.显式规则说明了,如何生成一个或多的的目标文件.这是由Makefile ...

  7. [转] Makefile 基础 (5) —— Makefile 使用变量

    该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神博客:(最原始版本) http://blog.csdn.net/haoel/article/details/2886 我转自 ...

  8. [转] Makefile 基础 (4) —— Makefile 书写命令

    该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神博客:(最原始版本) http://blog.csdn.net/haoel/article/details/2886 我转自 ...

  9. [转] Makefile 基础 (2) —— Makefile 总述

    该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神博客:(最原始版本) http://blog.csdn.net/haoel/article/details/2886 我转自 ...

  10. [转] Makefile 基础 (1) —— Makefile 介绍

    该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神博客:(最原始版本) http://blog.csdn.net/haoel/article/details/2886 我转自 ...

随机推荐

  1. 分类算法-----KNN

    摘要: 所谓K最近邻,就是k个最近的邻居的意思,说的是每个样本都可以用她最接近的k个邻居来代表.kNN算法的核心思想是如果一个样本在特征空间中的k个最相似的样本中的大多数属于某一个类别,则该样本也属于 ...

  2. jq中的css-Dom

    1,height() ,width() 此方法用来获取匹配元素的高和宽的值,如果括号内有值,则是修改匹配元素的值, 2.offset() 此方法的作用是获取元素在当前视窗的相对偏移,其中返回的对象包含 ...

  3. 剑指offer替换空格

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 ...

  4. CentOS/RHEL 7中的firewall控制

    从CentOS/RHEL 7开始firewall的使用.很多人卸载了firewall重装iptables.但是有时候只是为了开放端口什么的,没有那个闲工夫卸载重装: 永久打开一个新端口(如TCP/80 ...

  5. push控制器 卡顿

    代码: RecommendController *rec = [[RecommendController alloc]init]; [self.navigationController pushVie ...

  6. Block 朴实理解

    转载自:http://www.cnblogs.com/lzz900201/archive/2013/04/17/3025340.html block是个什么玩意儿 Block是Apple Inc.为C ...

  7. Kali-linux安装之后的简单设置--转载

       1.更新软件源:修改sources.list文件:leafpad /etc/apt/sources.list然后选择添加以下适合自己较快的源(可自由选择,不一定要全部): #官方源deb htt ...

  8. SDAU课程练习--problemB(1001)

    题目描述 There is a pile of n wooden sticks. The length and weight of each stick are known in advance. T ...

  9. js中的全局函数

    以前没搞懂JS的全局函数,全局函数和window对象的函数不一样.全局函数不属于任何一个内置对象. JS包含以下7个全局函数,用于一些常用的功能:escape(),eval(),isNan(),isF ...

  10. HDU 4638 (莫队)

    题目链接:Problem - 4638 做了两天莫队和分块,留个模板吧. 当插入r的时候,设arr[r]代表r的位置的数字,判断vis[arr[r-1]]和vis[arr[r+1]]是否访问过,如果两 ...