makefile文件编写_九图记住Makefile
本文首次編輯時間2020.07.20
最后編輯時間2020.08.03
歡迎轉載,轉載請附上原文鏈接
參考:
GNU make說明文檔:https://www.gnu.org/software/make/manual/html_node/index.html#SEC_Contents
【跟我一起寫Makefile】:https://seisman.github.io/how-to-write-makefile/
前言
Makefile的撰寫只是為了自動化流程,如果是Windows 程序開發者,IDE(Integrated Development Environment)已經集成好了編譯工具和make工具,不需要我們再手工編寫Makefile。但是在嵌入式開發中,我們都會在Linux平臺上進行開發然后交叉編譯,這時就需要我們自己手工完成編譯過程,所以Makefile必不可少。說開又說,學習Makefile是嵌入式開發者的必經之路,也只有清楚整個項目的編譯過程,才能對嵌入式開發有更好的理解。本文不適合Makefile從零開始的開發者。這里只是以圖表的形式對Makefile的編寫做知識歸納,也方便自己以后復習和查找相關資料。
一、解釋編譯和鏈接
以C/C++代碼為例,我們編寫完代碼后變成可執行文件需要經過編譯和鏈接階段。這個過程如果在Windows下是由IDE內置的編譯器和鏈接器完成的。但是在Unix系統我們需要自己處理這個過程。以圖解表示如下
編譯和鏈接二、Make的工作流程
Make的工作流程在 Makefile 中,規則的順序是很重要的,因為,Makefile 中只應該有一個最終目標,
其它的目標都是被這個目標所連帶出來的,所以一定要讓 make 知道你的最終目標是什么。
一般來說,定義在 Makefile 中的目標可能會有很多,但是第一條規則中的目標將被確立為
最終的目標。如果第一條規則中的目標有很多個,那么,第一個目標會成為最終的目標。 make所完成的也就是這個目標
三、書寫依賴規則
make實際上只是檢查Makefile里面的依賴關系(規則),然后決定哪一條規則下面的命令會被執行。命令執行成功與否make并不管
Makefile的規則書寫辦法四、書寫命令
當make檢查到某一條規則里,依賴文件比目標文件更新的情況時,就會執行該規則下的命令
Makefile命令的書寫五、使用變量
Makefile中的變量使用得最多最頻繁的,可能是自動化變量了
Makefile中的自動化變量六、使用函數
字符串處理函數文件名操作函數邏輯類函數總結
以上是生活随笔為你收集整理的makefile文件编写_九图记住Makefile的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 银杏的功效与作用
- 下一篇: markdown 字体颜色_一文搞定Ma