多个文件目录下Makefile的写法

一、前言php

  目前从事于linux下程序开发,涉及到多个文件,多个目录,这时候编译文件的任务量比较大,须要写Makefile。关于Makefile的详细内容能够参考网上流传很是普遍的《跟我一块儿写Makefile》http://blog.csdn.net/haoel/article/details/2886/,做者是个大牛,很是佩服。html

二、简单测试linux

  测试程序在同一个文件中,共有func.h、func.c、main.c三个文件,Makefile写法以下所示:web

复制代码
 CC = CFLAGS = -g -       $(CC)  main.o func.o -      $(CC) $(CFLAGS)  -c main.c -      $(CC) $(CFLAGS) -c func.c -      rm -rf *.o
复制代码

执行过程以下图所示:函数

三、通用模板测试

  实际当中程序文件比较大,这时候对文件进行分类,分为头文件、源文件、目标文件、可执行文件。也就是说一般将文件按照文件类型放在不一样的目录当中,这个时候的Makefile须要统一管理这些文件,将生产的目标文件放在目标目录下,可执行文件放到可执行目录下。测试程序以下图所示:spa

完整的Makefile以下所示:.net

复制代码
 DIR_INC = ./ DIR_SRC = ./ DIR_OBJ = ./ DIR_BIN = ./  SRC = $(wildcard ${DIR_SRC}
复制代码

解释以下:code

(1)Makefile中的 符号 $@, $^, $< 的意思:
  $@  表示目标文件
  $^  表示全部的依赖文件
  $<  表示第一个依赖文件
  $?  表示比目标还要新的依赖文件列表orm

(2)wildcard、notdir、patsubst的意思:

  wildcard : 扩展通配符
  notdir : 去除路径
  patsubst :替换通配符

 例以下图例子所示:

输出结果以下所示:

SRC = $(wildcard *.c)

等于指定编译当前目录下全部.c文件,若是还有子目录,好比子目录为inc,则再增长一个wildcard函数,象这样:

SRC = $(wildcard *.c) $(wildcard inc/*.c)

(3)gcc -I -L -l的区别:

       gcc -o hello hello.c -I /home/hello/include -L /home/hello/lib -lworld

       上面这句表示在编译hello.c时-I /home/hello/include表示将/home/hello/include目录做为第一个寻找头文件的目录,

   寻找的顺序是:/home/hello/include-->/usr/include-->/usr/local/include

   -L /home/hello/lib表示将/home/hello/lib目录做为第一个寻找库文件的目录,

   寻找的顺序是:/home/hello/lib-->/lib-->/usr/lib-->/usr/local/lib

       -lworld表示在上面的lib的路径中寻找libworld.so动态库文件(若是gcc编译选项中加入了“-static”表示寻找libworld.a静态库文件)

参考:

http://www.groad.net/bbs/read.php?tid-2920-page-e.html

http://blog.csdn.net/liangkaiming/article/details/6267357

http://blog.csdn.net/zqt520/article/details/7727051

相关文章
相关标签/搜索