Makefile 讀書筆記(一)

Makefile文件概述

一. Makefile 文件格式

target ... : prerequisites ...
        command
        ...
        ...
"target"通常是可執行文件或者object文件
“prerequisite”爲target文件所依賴的文件
"command"是make命令執行的動作

二. 一個簡單的Makefile實例

在這個例子中,所有的C文件都包含'defs.h'
edit : main.o kbd.o command.o display.o /
       insert.o search.o files.o utils.o
        cc -o edit main.o kbd.o command.o display.o /
                   insert.o search.o files.o utils.o
main.o : main.c defs.h
        cc -c main.c
kbd.o : kbd.c defs.h command.h
        cc -c kbd.c
command.o : command.c defs.h command.h
        cc -c command.c
display.o : display.c defs.h buffer.h
        cc -c display.c
insert.o : insert.c defs.h buffer.h
        cc -c insert.c
search.o : search.c defs.h buffer.h
        cc -c search.c
files.o : files.c defs.h buffer.h command.h
        cc -c files.c
utils.o : utils.c defs.h
        cc -c utils.c
clean :
        rm edit main.o kbd.o command.o display.o /
           insert.o search.o files.o utils.o

三.在Makefile中使用變量

可以使用變量名爲objects,OBJECTS,objs,OBJS,obj或者OBJ作爲一組object文件的名字,於是,上面的例子可以簡化爲:
objects = main.o kbd.o command.o display.o /
          insert.o search.o files.o utils.o
objects = main.o kbd.o command.o display.o /
          insert.o search.o files.o utils.o
edit : $(objects)
        cc -o edit $(objects)
main.o : main.c defs.h
        cc -c main.c
kbd.o : kbd.c defs.h command.h
        cc -c kbd.c
command.o : command.c defs.h command.h
        cc -c command.c
display.o : display.c defs.h buffer.h
        cc -c display.c
insert.o : insert.c defs.h buffer.h
        cc -c insert.c
search.o : search.c defs.h buffer.h
        cc -c search.c
files.o : files.c defs.h buffer.h command.h
        cc -c files.c
utils.o : utils.c defs.h
        cc -c utils.c
clean :
        rm edit $(objects)

四.精簡命令

Makefiel 的隱含機制可以爲.o文件省略.c文件,上面的例子可以進一步簡化爲:
objects = main.o kbd.o command.o display.o /
          insert.o search.o files.o utils.o
edit : $(objects)
        cc -o edit $(objects)
main.o : defs.h
kbd.o : defs.h command.h
command.o : defs.h command.h
display.o : defs.h buffer.h
insert.o : defs.h buffer.h
search.o : defs.h buffer.h
files.o : defs.h buffer.h command.h
utils.o : defs.h
.PHONY : clean
clean :
        rm edit $(objects)

五.Makefile文件的另一種形式

objects = main.o kbd.o command.o display.o /
          insert.o search.o files.o utils.o
edit : $(objects)
        cc -o edit $(objects)
$(objects) : defs.h
kbd.o command.o files.o : command.h
display.o insert.o search.o files.o : buffer.h
發佈了17 篇原創文章 · 獲贊 10 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章