makefile实践例子

最近系统学习了下Makefile,自己实现了一个包含文件搜索,并将生成的.o文件单独生成到固定目录下面的例子。

文件结构

makefile

testmain.c

pub

    basehead.h

print

   print.c

   print.h

command

   command.c

   command.h

makefile文件内容:

#变量的定义,用来将不同用途的文件归类
tmpfile = tmp dep obj

objfile = obj

MoudleH = print command pub

Moudle = print command  .

#用来遍历产生.c和.h文件

srcfile = $(foreach moudle,$(Moudle),$(wildward $(moudel)/*.c))    

Headfile = $(foreach moudle,$(MoudleH),$(wildward $(moudel)/*.h))

#用来生成目标的.o文件

objs = $(addprefix $(objfile)/,$(subst .c,.o,$(notdir $(srcfile))))

#设置文件搜索的相关路径

pathfile = -Icommand -Ipub -Iprint

vpath  %.c print command

vpath  %.h print command pub

#makefile的第一个目标作为入口开始

default: printmain TestMakeFile

#用来打印遍历产生的文件,以方便查看结果是否正确

printmain:

      @echo $(Headfile)

     @echo $(srcfile)

     @echo $(objs)

#链接产生相应的执行文件

TestMakeFile:$(objs)

    gcc $+ $(pathobj) -o TestMakeFile

#编译产生.o文件,并放到指定的obj目录中

$(objfile)/%.o: %.c

    @echo ----begin---

     gcc $(pathfile) -c $< -o $@

    @echo ----end----

#用来创建临时文件

mkdirMain:

    mkdir $(tmpfile)

#用来删除生成的文件

clean:

    rm -rf TestMakeFile $(tmpfile)

运行结果:

能够通过目录搜索获取相应的.c和.h文件,并能将.o文件放到指定的obj文件中

 

 

你可能感兴趣的:(makefile实践例子)