Linux學習筆記——例說makefile 多個檔案

xukai871105發表於2014-07-02
0.前言
    從學習C語言開始就慢慢開始接觸makefile,查閱了很多的makefile的資料但總感覺沒有真正掌握makefile,如果自己動手寫一個makefile總覺得非常吃力。所以特意藉助部落格總結makefile的相關知識,通過例子說明makefile的具體用法。
    例說makefile分為以下幾個部分,更多內容請參考【例說makefile索引博文
    1.只有單個C檔案   
    2.含有多個C檔案    
    3.需要包括標頭檔案路徑
    4.增加巨集定義
    5.增加系統共享庫
    6.增加自定義共享庫
    7.一個實際的例子

    【程式碼倉庫】——makefile-example
    程式碼倉庫位於bitbucket,可藉助TortoiseHg(GUI工具)克隆程式碼或者在網頁中直接下載zip包。

1.三個C檔案
    三個檔案位於同一個目錄中。
    【test.c】
#include <stdio.h>
int main(void)
{
    int a = 3;
    int b = 2;
        
    printf("a=%d\n", a);
    printf("b=%d\n", b);
    
    printf("a+b=%d\n", add(a,b));
    printf("a-b=%d\n", sub(a,b));
    return 0;
}
    
    【test-add.c】
int add(int a, int b) 
{
    return a+b;
}
    
    【test-sub.c】
int sub(int a, int b) 
{
    return a-b;
}

2.複習GCC指令
    多個C檔案和單個C檔案的處理過程相似,此時-c或-o之後可以增加多個C檔案或目標檔案。
    【編譯原始檔】
    gcc -c test.c test-add.c test-sub.c
    【連結目標檔案】
    gcc -o test test.o test-add.o test-sub.o
    【執行目標檔案】
    ./test
    【控制檯輸出】
    a=3
    b=2
    a+b=5
    a-b=1

3.編寫makefile檔案
    【makefile】
    請替換其中的[tab],並以程式碼倉庫中的makefile檔案為主。
# 指令編譯器和選項
CC=gcc
CFLAGS=-Wall -std=gnu99

# 目標檔案
TARGET=test
# 原始檔
SRCS=test.c test-add.c test-sub.c

OBJS = $(SRCS:.c=.o)

$(TARGET):$(OBJS)
#	@echo TARGET:$@
#	@echo OBJECTS:$^
[tab]$(CC) -o $@ $^

clean:
[tab]rm -rf $(TARGET) $(OBJS)

%.o:%.c
[tab]$(CC) $(CFLAGS) -o $@ -c $<

    【具體說明】
    【1】更多說明請參考:例說makefile——單個檔案
    【2】相對於單個檔案,此處僅修改了SRCS=test.c test-add.c test-sub.c,變數SRCS追加了多個C檔案。相比單個檔案的情況,僅僅修改了這一行。
    【3】檔案和檔案之間通過空格隔開。
    【執行過程】
    make clean && make 
    【控制檯輸出】
rm -rf test test.o test-add.o test-sub.o
gcc -Wall -std=gnu99 -o test.o -c test.c
gcc -Wall -std=gnu99 -o test-add.o -c test-add.c
gcc -Wall -std=gnu99 -o test-sub.o -c test-sub.c
gcc -o test test.o test-add.o test-sub.o
    從控制檯的輸出可以看出,通過make clean清除上一次的可執行檔案和目標檔案,然後依次編譯各個C檔案,最後把3個目標檔案連結為最終可執行檔案。


相關文章