• 学习资料

本文主要参考资料:驾驭Makefile(李云).pdf

  • 原理

(1)最基本的语法

targets: prerequisites

  command

targets是目标,prerequisites是先决条件,目标依赖于先决条件。

command是生成目标的命令。

这一整个形式就是规则。

(2)目标的生成

一个目标的生成(目标不存在或者依赖比目标新才会重新创建目标):

(1)先判断目标是否有依赖,有则寻找相应规则生成依赖;

(2)没有依赖,运行命令生成target。

(3)依赖的生成递归调用(1)和(2)

如下图所示:

(3)Makefile目标语法

  • 默认目标为第一个目标
  • 伪目标,可以用.PHONY: clean【避免与现有的文件同名】
  • simple项目

写Makefile文件之前,需要先想好依赖关系,再进行编写。

假设现在有foo.c和main.c两个文件,则依赖关系如下:

    foo.o    foo.c

simple

    main.o   main.c

生成main.o命令:gcc -o main.o -c main.c

生成foo.o命令:gcc -o simple main.o foo.o

gcc的-o选项,指定输出文件的文件名

gcc的-c选项,仅作预处理、编译和汇编并生成目标文件

  • 变量

(1)变量定义及引用

定义:EXE = simple

引用:$(EXE)或${EXE}

(2)特殊变量

$(MAKE) -》 make命令名是什么

$(MAKECMDGOALS) -》 make的目标是什么

(3)变量的类别

EXE = simple 递归扩展变量

EXE := simple 简单拓展变量,只进行一次扫描和替换

EXE ?= simple 条件赋值变量,当前变量以前没有定义就进行赋值,否则不处理

(4)自动变量

目标和先决条件在规则的命令中多次出现,应尽量避免

$@是指 造成命令运行的目标(可能有多个)。

$^是所有先决条件

$<是第一个先决条件

(5)变量来源

  • Makefile定义的变量
  • 自动变量,如$@ $^ $<等,根据上下文自动获得变量值
  • Shell环境
  • 在运行make命令是定义变量

(6)高级变量引用

$(EXE:.o=.c)自动完成后缀替换,可用patsubst完成同样的功能。

(7)override指令

不希望Makefile文件中定义的变量被覆盖掉。

  • 模式

对于多个规则去生成多个目标文件,如main.o和foo.o都有一条规则进行描述。

每一个object文件都有一条规则的话,这是非常麻烦的。

%.o : %.c ;
<command ......>;

在模式规则中,目标可能会是多个的,如果有模式匹配出多个目标,make就会产生所有的模式目标。

如果要生成的目标是 a.o b.o,那么%c 就是 a.c b.c,则会产生两个目标,规则分别如下。

foo.o : foo.c ;
<command ......>;
main.o : main.c ;
<command ......>;
  • 函数

(1)wildcard

在Makefile规则中,通配符会被自动展开,但在变量的定义和函数引用时,通配符将失效。

如果需要通配符有效,就需要使用函数“wildcard”,用法是:$(wildcard PATTERN...) ,如$(wildcard *.c)。

在Makefile中,它被展开为已经存在的、使用空格分开的、匹配此模式的所有文件列表

如果不存在任何符合此模式的文件,函数会忽略模式字符并返回空

(2)patsubst

patsubst函数是用来进行字符串替换的,语法:

$(patsubst pattern, replacement, text)

eg:$(patsubst %.c, %.o, $(mixed))

(3)addprefix

addprefix函数是用来给字符串的每个子字符串前加上一个前缀,语法:

$(addprefix prefix, names...)

(4)filter

filter函数用于从一个字符串中,根据模式得到满足模式的字符串,语法:

$(filter pattern..., text)

(5)filter-out

filter-out函数用于从一个字符串中,根据模式去除满足模式的字符串,语法:

$(filter-out pattern..., text)

(6)strip

strip函数用于去除变量中多余的空格,语法:

$(strip string)

Makefile文件应用——simple项目的更多相关文章

  1. Makefile文件应用——huge项目

    提高复用性 在build目录下,保存公用部分make.rule (1)绝对路径 用ROOT变量保存项目根目录 (2)增加控制变量 EXE/LIB/ (3)头文件查找目录 gcc 的-I(i的大写)选项 ...

  2. Makefile文件应用——complicated项目

    学习资料 本文主要参考资料:驾驭Makefile(李云).pdf Complicated项目 需求: (1)object文件放到objs目录下 (2)可执行文件放到exes目录下 (3)增加头文件依赖 ...

  3. 简单编写makefile文件,实现GCC4.9编译项目,增加boost库測试等等。。

    一.须要用到的hw.cpp hw.h funtest.cpp funtest.h makefile 几个測试文件 1.hw.cpp代码例如以下: #include "hw.h" # ...

  4. 利用 autoconf 和 automake 生成 Makefile 文件

    一.相关概念的介绍 什么是 Makefile?怎么书写 Makefile?竟然有工具可以自动生成 Makefile?怎么生成啊?开始的时候,我有这么多疑问,所以,必须得先把基本的概念搞个清楚. 1.M ...

  5. linux下使用automake工具自动生成makefile文件

    linux环境下,当项目工程很大的时候,编译的过程很复杂,所以需要使用make工具,自动进行编译安装,但是手写makefile文件比较复杂,所幸在GNU的计划中,设计出了一种叫做Autoconf/Au ...

  6. Linux内核Makefile文件(翻译自内核手册)

    --译自Linux3.9.5 Kernel Makefiles(内核目录documention/kbuild/makefiles.txt) kbuild(kernel build) 内核编译器 Thi ...

  7. makefile文件的技术

    [快速的学习笔记] gcc命令:http://www.cnblogs.com/ggjucheng/archive/2011/12/14/2287738.html#_Toc311642845 makef ...

  8. Linux平台Makefile文件的编写基础篇(转)

    目的:       基本掌握了 make 的用法,能在Linux系统上编程.环境:       Linux系统,或者有一台Linux服务器,通过终端连接.一句话:有Linux编译环境.准备:      ...

  9. Linux Makefile文件编写详细步骤与实践

    Linux Makefile文件编写详细步骤与实践 1.makefile概述 Windows环境下IDE会帮你完成makefile文件的编写,但在UNIX环境下你就必须自己写makefile了,会不会 ...

随机推荐

  1. [USACO5.5]隐藏口令Hidden Password

    题目链接:传送门 题目大意:给你一个长度 N 的字符串,5<=N<=5,000,000,将首尾合并成环,断环成链并满足字典序最小,输出此时首字母在原串中的位置-1: 题目思路:最小表示法 ...

  2. 160711、Java 多线程核心技术梳理

    本文对多线程基础知识进行梳理,主要包括多线程的基本使用,对象及变量的并发访问,线程间通信,lock 的使用,定时器,单例模式,以及线程状态与线程组. java 多线程 基础知识 创建线程的两种方式:1 ...

  3. MySQL安装和Navicat安装、破解

    1)mysql下载 地址:https://dev.mysql.com/downloads/mysql/ 2)一路next安装,安装好后文件目录如下(不包括data文件夹,my.ini文件) 3)新建文 ...

  4. 『浅入深出』MySQL 中事务的实现

    在关系型数据库中,事务的重要性不言而喻,只要对数据库稍有了解的人都知道事务具有 ACID 四个基本属性,而我们不知道的可能就是数据库是如何实现这四个属性的:在这篇文章中,我们将对事务的实现进行分析,尝 ...

  5. 【Python之路】第十七篇--Ajax全套

    概述 1.传统的Web应用 一个简单操作需要重新加载全局数据 2.AJAX AJAX,Asynchronous JavaScript and XML (异步的JavaScript和XML),一种创建交 ...

  6. table width 决定 td width

    w td width 有无在chrome edge ff 均未影响td实际宽度,td接近等比分配table width. <!doctype html> <html lang=&qu ...

  7. centos7 Dockerfile安装nginx

    1.写一个Dockerfile文件 FROM centos MAINTAINER apeng apeng@apenglinux-002.com RUN yum install -y pcre-deve ...

  8. 在启动MYSQL时出现问题:“ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)”

    1.问题描述 在启动MYSQL时出现问题:"ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)& ...

  9. python线程间数据共享(示例演示)

    ``` import threading data_list = [] def task(arg): data_list.append(arg) print(data_list) def run(): ...

  10. MySQL数据库(3)- 完整性约束、外键的变种、单表查询

    一.完整性约束 在创建表时候,约束条件和数据类型的宽度都是可选参数. 作用:用于保证数据的完整性和一致性. 1.not null(不可空)与default 示例一:插入一个空值,如下: mysql&g ...