多個文件目錄下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

相關文章
相關標籤/搜索