make 簡單命令

  首先先看一下什麼是makefile
    
    makefile定義了一系列的規則來指定,哪些文件需要先編譯,哪些文件需要後編譯,哪些文件需要重新編譯,甚至於進行更復雜的功能操作,因爲 makefile就像一個Shell腳本一樣,其中也可以執行操作系統的命令。
    
    makefile帶來的好處就是--“自動化編譯”,一旦寫好,只需要一個make命令,整個工程完全自動編譯,極大的提高了軟件開發的效率。make是一個命令工具,是一個解釋makefile中指令的命令工具,一般來說,大多數的IDE都有這個命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make.可見,makefile都成爲了一種在工程方面的編譯方法。
    
    make
    
    根據Makefile文件編譯源代碼、連接、生成目標文件、可執行文件。
    
    make clean
    
    清除上次的make命令所產生的object文件(後綴爲“.o”的文件)及可執行文件。
    
    make install
    
    將編譯成功的可執行文件安裝到系統目錄中,一般爲/usr/local/bin目錄。
    
    make dist
    
    產生髮布軟件包文件(即distribution package)。這個命令將會將可執行文件及相關文件打包成一個tar.gz壓縮的文件用來作爲發佈軟件的軟件包。
    
    它會在當前目錄下生成一個名字類似“PACKAGE-VERSION.tar.gz”的文件。PACKAGE和VERSION,是我們在configure.in中定義的AM_INIT_AUTOMAKE(PACKAGE, VERSION)。
    
    make distcheck
    
    生成發佈軟件包並對其進行測試檢查,以確定發佈包的正確性。這個操作將自動把壓縮包文件解開,然後執行configure命令,並且執行make,來確認編譯不出現錯誤,最後提示你軟件包已經準備好,可以發佈了。
    
    make distclean
    

    類似make clean,但同時也將configure生成的文件全部刪除掉,包括Makefile文件。



一個簡單的makefile例子


 相信在unix下編程的沒有不知道makefile的,剛開始學習unix平臺
下的東西,瞭解了下makefile的製作,覺得有點東西可以記錄下。
  下面是一個極其簡單的例子:
現在我要編譯一個Hello world,需要如下三個文件:
  1. print.h
      #include<stdio.h>
      void printhello();

  2. print.c
      #include"print.h"
      void printhello(){
        printf("Hello, world\n");
      }

   3. main.c
      #include "print.h"
      int main(void){
        printhello();
        return 0;
      }

  好了,很簡單的程序了。如果我們想要編譯成功需要哪些步驟呢?
我認爲在這裏需要理解的就兩步:
  #  爲每一個 *.c文件生成 *o文件。
  #  連接每一個*o文件,生成可執行文件。
下面的makefile 就是根據這樣的原則來寫的。

 

一:makefile 雛形:

 
#makefile的撰寫是基於規則的,當然這個規則也是很簡單的,就是:
#target : prerequisites 
  command  //任意的shell 命令

實例如下:
makefile:
    helloworld : main.o print.o #helloword 就是我們要生成的目標
                 # main.o print.o是生成此目標的先決條件
      gcc -o helloworld main.o print.o#shell命令,最前面的一定是一個tab鍵

    mian.o : mian.c print.h
      gcc -c main.c
    print.o : print.c print.h
      gcc -c print.c
    
    clean :          
        rm helloworld main.o print.o
  OK,一個簡單的makefile製作完畢,現成我們輸入 make,自動調用Gcc編譯了,
輸入 make clean就會刪除 hellowworld mian.o print.o


二:小步改進:


  在上面的例子中我們可以發現 main.o print.o 被定義了多處,
我們是不是可以向C語言中定義一個宏一樣定義它呢?當然可以:
makefile:
    objects =  main.o print.o #應該叫變量的聲明更合適

    helloworld : $(objects) //聲明瞭變量以後使用就要$()了
      gcc -o helloworld$(objects)
     mian.o : mian.c print.h
      gcc -c main.c
    print.o : print.c print.h
      gcc -c print.c
    
    clean :          
        rm helloworld $(objects)
修改完畢,這樣使用了變量的話在很多文件的工程中就能體現出方便性了。


三:再進一步:


  再看一下,爲沒一個*.o文件都寫一句gcc -c main.c是不是顯得多餘了,
能不能把它幹掉?而且 main.c 和print.c都需要print.h,爲每一個都寫上是
不是多餘了,能不能再改進?
能,當然能了:
makefile:
     objects =  main.o print.o

    helloworld : $(objects) 
      gcc -o helloworld$(objects)
    
    $(objects) : print.h # 都依賴print.h
     mian.o : mian.c  #幹掉了gcc -c main.c 讓Gun make自動推導了。
    print.o : print.c     
    clean :          
        rm helloworld $(objects)

好了,一個簡單的makefile就這樣完畢了,簡單吧。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章