Makefile学习(三)[第二版]

make常用内嵌函数

1、函数调用

$(function arguments) #$引用的结果就是函数生成的结果

2、Makefile下常用的函数

1)$(wildcard PATTERN) #匹配当前目录下的文件

例如:src=$(wildcard *.c) #匹配当前目录下所有的.c文件

2)$(patsubst PATTERN,REPLACEMENT,TEXT) #模式替换函数

例如:$(patsubst %.c,%.o,$src) #等价于$(src:%.c=%.o)[常用]

3)shell函数,执行shell命令

例如:$(shell ls –d */)

多级目录Makefile

#示例1-所有的编译均由主目录下的Makefile完成

CC = gcc

CFLAGS   = -Wall -g

BIN      = main

SUBDIR   = $(shell ls -d */) #SUBDIR保存了当前目录下的子目录

ROOTSRC  = $(wildcard *.c) #ROOTSRC保存了当前目录下的.c文件

ROOTOBJ  = $(ROOTSRC:%.c=%.o) #ROOTOBJ保存了将ROOTSRC中.c替换为.o文件之后的结果

SUBSRC   = $(shell find $(SUBDIR) -name ‘*.c‘) #SUBSRC保存了所有子目录下的所有.c文件

SUBOBJ   = $(SUBSRC:%.c=%.o) #SUBOBJ保存了将SUBSRC中.c替换为.o文件之后的结果

$(BIN):$(ROOTOBJ) $(SUBOBJ)

$(CC) $(CFLAGS) -o $(BIN) $(ROOTOBJ) $(SUBOBJ)

%.o:%.c

$(CC) $(CFLAGS) -c $< -o [email protected] #将所有的.c生成.o文件

clean:

rm -f $(BIN) $(ROOTOBJ) $(SUBOBJ)

#示例2-各个子目录下都有想对应的Makefile文件,各个子目录负责相应的编译工作

DIRS = lib intro sockets advio daemons datafiles db environ \

fileio filedir ipc1 ipc2 proc pty relation signals standards \

stdio termios threadctl threads printer exercises

all:

for i in $(DIRS); do \

(cd $$i && echo "making $$i" && $(MAKE) ) || exit 1; \

done

clean:

for i in $(DIRS); do \

(cd $$i && echo "cleaning $$i" && $(MAKE) clean) || exit 1; \

done

生成分布在多个目录下的可执行文件

#每个子目录都需要生成一个可执行文件,当前目录的结构如下图

#各个文件的内容如下

//test1/test1.c
#include <stdio.h>

int main()
{
    printf("Hello !\n");
    return 0;
}

#test1/Makefile

.PHONY: all clean print

CC = gcc

CFLAGS = -Wall -g

BIN = test1

SOURCES = $(wildcard *.c)

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

all: print $(BIN)

print:

@echo "----- make all in $(PWD) -----"

$(BIN): $(OBJECTS)

$(CC) $(CFLAGS) -o [email protected] $^

#$(OBJECTS): $(SOURCES)

%.o: %.c

$(CC) $(CFLAGS) -o [email protected] -c $<

clean:

@echo "---- make clean in $(PWD) -----"

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

//test2/test2.cpp
#include <iostream>
using namespace std;

int main(void)
{
    cout << "World!" << endl;
}

#test2/Makefile

.PHONY: clean all print

CXX = g++

CPPFLAGS = -Wall -g

BIN = test2

SOURCES = $(wildcard *.cpp)

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

all: print $(BIN)

print:

@echo "----- make all in $(PWD) -----"

$(BIN): $(OBJECTS)

$(CXX) $(CPPFLAGS) -o [email protected] $<

%.o: %.cpp  #可以省略该行以及下面一行

$(CXX) $(CPPFLAGS) -o [email protected] -c $<

clean:

@echo "----- make clean in $(PWD) -----"

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

#Makefile-在主目录下

SUBDIR = $(shell /bin/ls -d */)

.PHONY: default all clean $(SUBDIR)

default: all

all clean:

$(MAKE) $(SUBDIR) [email protected]

$(SUBDIR):

$(MAKE) -C [email protected] $(TARGET)

#执行make之后的结果

#执行后的目录结构图

增添了好多文件[.o 和 可执行文件]

#执行make clean的结果

#执行之后的结构图

恢复原样O(∩_∩)O~

时间: 2024-11-05 02:30:26

Makefile学习(三)[第二版]的相关文章

Makefile学习(一)[第二版]

简介 1)make:利用 make 工具可以自动完成编译工作.这些工作包括:如果仅修改了某几个源文件,则只重新编译这几个源文件[make通过比对相应的.c文件与.o文件的时间];如果某个头文件被修改了,则重新编译所有包含该头文件的源文件.利用这种自动编译可大大简化开发工作,避免不必要的重新编译. 2)Mackfile:make工具通过一个称为 Mackfile 的文件来完成并自动维护编译工作.Mackfile文件描述了整个工程的编译.连接等规则. Mackfile基本规则 Target ...:

gdb学习(二)[第二版]

查看运行时数据 print - 查看变量值 ptype – 查看变量类型 #ptype i #ptype "aaa" 打印字符串"aaa"的类型 #ptype array 打印数组array的类型 #ptype main 打印main函数的类型 print array – 查看数组 #p arr1 #p arr1[2] 查看数组arr2第三个元素值 #p &arr1[2] 打印数组元素的地址 #p &arr1 打印数组首地址,与p &arr1

gcc学习(一)[第二版]

gcc简介 1. gcc是GNU Compiler Collection的缩写.最初是作为C语言的编译器(GNU C  Compiler),作者为Richard Stallman,是GNU项目的奠基者;现在已经支持多种语言,如C.C++.Java.Pascal.Ada.COBOL语言等 . 2.主要特征: gcc是一个可移植的编译器,支持多种硬件平台,甚至对Don Knuth 设计的 MMIX 这类不常见的计算机都提供了完善的支持 gcc不仅仅是个本地编译器,它还能跨平台交叉编译(在本地编译的程

Makefile学习(三)

 make常用内嵌函数 1.函数调用 $(function arguments) #$引用的结果就是函数生成的结果 2.Makefile下常用的函数 1)$(wildcard PATTERN) #匹配当前目录下的文件 例如:src=$(wildcard *.c) #匹配当前目录下所有的.c文件 2)$(patsubst PATTERN,REPLACEMENT,TEXT) #模式替换函数 例如:$(patsubst %.c,%.o,$src) #等价于$(src:%.c=%.o)[常用] 3)

gcc学习(二)[第二版]

头文件与库文件 1.概要 在使用C语言和其它语言进行程序设计的时候,我们须要头文件来提供对常数的定义和对系统及库函数调用的声明. 库文件是一些预先编译好的函数集合,那些函数都是依照可重用原则编写的.它们通常由一组互相关联的用来完毕某项常见工作的函数构成.比方用来处理屏幕显示情况的函数(ncurses库)和数据库訪问例程(dbm库)等. 2.使用库的长处: 1)模块化开发 2)可重用性 3)可维护性 3.头文件与库文件的位置 /usr/include及其子文件夹底下的include文件夹 /usr

学习bash第二版 学习笔记 1 —— bash的简介、检测和安装

shell 区别于内核 是一款命令解析程序. Bourne Again shell (BASH), 创建用于GNU项目. GNU项目由Free Software Foundation(FSF)的Richard Stallman 始创,用于创建一个UNIX兼容的操作系统, 并使用该免费的发布版本替代所有的商业UNIX版本. ?? 你可能不能马上用bash.你的系统管理员可能将你的账号设置为使用系统上的 "标准" shell,你甚至不知道有没有其他shell可用. ?? 键入 echo $

python基础学习09(核心编程第二版)部分

# -*- coding: utf-8 -*- # ==================== #File: python #Author: python #Date: 2014 #==================== __author__ = 'Administrator' #什么是函数 #就是引用,创建,使用 #例子 def foo(): print '233' foo() #返回与函数类型 def foo1():#是一个过程 print 'hello world!' foo1() foo

o&#39;Reill的SVG精髓(第二版)学习笔记——第八章

第八章:图案和渐变 要使用图案,首先要定义一个水平或者垂直方向重复的图形对象,然后用它填充另一个对象或者作为笔画使用.这个图形对象呗称作tile(瓷砖). 下面可以把SVG绘制的二次曲线作为图案. <!-- 图案的路径 --> <path d="M 0 0 Q 5 20 10 10 T 20 20" style="stroke: black;fill:none;" /> <path d="M 0 0 h20 v20 h-20

o&#39;Reill的SVG精髓(第二版)学习笔记——第十一章

第十一章:滤镜 11.1滤镜的工作原理 当SVG阅读器程序处理一个图形对象时,它会将对象呈现在位图输出设备上:在某一时刻,阅读器程序会把对象的描述信息转换为一组对应的像素,然后呈现在输出设备上.例如我们用SVG的<filter>元素指定一组操作(也称作基元,primitive),在对象的旁边显示一个模糊的投影,然后把这个滤镜附加给一个对象: <fliter id="drop-shadow"> <!-- 这是滤镜操作 --> </fliter&g