我是靠谱客的博主 谨慎小鸽子,最近开发中收集的这篇文章主要介绍Makefile的一种通用写法以及其中的字段含义,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

管理Linux环境下的C/C++大型项目,本文描述Linux环境下大型工程项目子目录Makefile的一种通用写法,使用该方法,当该子目录内的文件有增删时无需对Makefile进行改动,可以说相当的智能。

下面先贴代码(为减小篇幅,一些非关键的代码被去掉,本方法的局限是用于一个C文件生成一个可执行文件的场合):

ROOTDIR = .

EXE_DIR = ./bin
CFLAGS = -I$(INCLUDE_DIR) -I$(LIB_INC) -Wall
LFLAGS = -L$(LIB_DIR)

objects := $(patsubst %.c,%.o,$(wildcard *.c))
executables := $(patsubst %.c,%,$(wildcard *.c))

all : $(objects)
$(objects) :%.o : %.c
    @mkdir -p ./bin$
    $(CROSS_COMPILE)gcc -c $(CFLAGS) $< -o $@
    $(CROSS_COMPILE)gcc $(CFLAGS) $< -o $(subst .o, ,$(EXE_DIR)/$@) $(LFLAGS) $(LIBS)
clean:
    @rm -f *.o rm -f $(executables)
    @rm -rf ./bin 
distclean: clean

假如当前目录里面有a.c b.c两个文件

      Makefile 里的函数跟它的变量很相似——使用的时候,你用一个$符号跟左圆括号,函数名,空格后跟一列由逗号分隔的参数,最后用右圆括号结束。例如,在GNU Make里有一个叫'wildcard' 的函数,它有一个参数,功能是展开成一列所有符合由其参数描述的文件名,文件间以空格间隔。像这个命令: 
 
    objects= $(wildcard *.c)    
 
  会产生一个所有以'.c' 结尾的文件列表(本例结果为a.c b.c),然后存入变量objects里。    
 
  另一个有用的函数是 patsubst ( patten substitude,匹配替换的缩写)函数。它需要3个参数——第一个是一个需要匹配的式样,第二个表示用什么来替换它,第三个是一个需要处理由空格分隔的序列。我们将两个函数合起来用:
 
objects := $(patsubst %.c,%.o,$(wildcard *.c))
 会被处理为: 
objects := a.o b.o
 同理: 
executables := $(patsubst %.c,%,$(wildcard *.c))
 会被处理为: 
executables := a b
 
%.o:所有以“.o”结尾的目标,也就是a.o b.o
 
依赖模式“%.c”:取模式“%.o”的%,也就是foo bar,并为其加上.c后缀,即a.c,b.c
 

$<:表示所有依赖目标集,也就是a.c b.c
 
$@:表示目标集,也就是a.o b.o
 
命令前加@,表示在终端中不打印,如@mkdir -p ./bin
 
$(objects) : %.o: %.c 
        $(CROSS_COMPILE)gcc -c $(CFLAGS) $< -o $@
 

即可翻译为: 


a.o b.o : a.c b.c    $(CROSS_COMPILE)gcc -c $(CFLAGS) (a.c b.c) -o (a.o b.o)
 
明白了这些,这种Makefile的写法就可以完全掌握了。
 
注:当前目录直接make的两种写法:

1:如果在当前目录中直接make的话使用下列代码:

#General Purpose Makefile by guoqingbo
                          
objects := $(patsubst %.c,%.o,$(wildcard *.c))  
executables := $(patsubst %.c,%,$(wildcard *.c))  
                          
all :  $(objects)
$(objects) : %.o: %.c 
    gcc -c $< -o $@
    gcc $< -o $(subst .o, ,$@) 
clean :
    @rm -rf *.o *~
    @rm -rf ${executables}
 .PHONY : clean

2:后来发现下列代码也可以有相同效果,难道使用了什么默认规则,还不是很明白,先记录下来:

#General Purpose Makefile by guoqingbo  
                            
executables := $(patsubst %.c,%,$(wildcard *.c))
                            
all : $(executables)

clean :  
    @rm -rf *.o *~  
    @rm -rf ${executables}  
.PHONY : clean

最后

以上就是谨慎小鸽子为你收集整理的Makefile的一种通用写法以及其中的字段含义的全部内容,希望文章能够帮你解决Makefile的一种通用写法以及其中的字段含义所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(42)

评论列表共有 0 条评论

立即
投稿
返回
顶部