軟件項(xiàng)目中引用頭文件的幾種方法及要點(diǎn)
作者 | strongerHuang
微信公眾號(hào) | 嵌入式專欄
下面就來說說與頭文件有關(guān)的知識(shí);
嵌入式專欄
1
#include使用引號(hào)“” 還是 尖括號(hào)<> 這個(gè)是有規(guī)定的。
通常來說:系統(tǒng)自帶的頭文件用尖括號(hào)括起來,這樣編譯器會(huì)在系統(tǒng)文件目錄下查找。
#include
用戶自定義的文件用雙引號(hào)括起來,編譯器首先會(huì)在用戶目錄下查找。
#include "xxx.h" 這里可以參看我之前分享的一篇文章:#include使用引號(hào)“”和尖括號(hào)<>的區(qū)別?
嵌入式專欄
2
一個(gè)項(xiàng)目通常有多個(gè)源文件,你要讓編譯器找到這些存儲(chǔ)在不同路徑下的源文件,就必須要讓編譯器知道源代碼所在(路徑)位置。
引用頭文件路徑的方式有多種,在代碼中添加路徑,在IDE工具中添加路徑,還有分絕對(duì)路徑和相對(duì)路徑。下面就來簡(jiǎn)單說說:
1.源代碼中引用頭文件
#include "/strongerhuang/robot/project/bsp/bsp_uart.h"#include "../bsp/bsp_uart.h" 但是,你會(huì)發(fā)現(xiàn)上面那個(gè)引用有什么區(qū)別嗎? 一個(gè)是絕對(duì)路徑:
#include "/strongerhuang/robot/project/bsp/bsp_uart.h" 一個(gè)是相對(duì)路徑:
#include "../bsp/bsp_uart.h"
2.IDE工具中引用頭文件
我們使用的Keil、IAR這種工具,可以不用像上面那樣,在源代碼中添加路徑頭文件,只需要在工程中配置編譯路徑即可。比如Keil MDK: 通過菜單 Project -> Options for Taget -> C/C++:
Keil MDK默認(rèn)是相對(duì)(工程文件的)路徑。
IAR EWARM類似: 通過菜單 Project -> Options -> C/C++ Compiler:
IAR 默認(rèn)是絕對(duì)路徑,通常我們需要修改為相對(duì)路徑。
嵌入式專欄
3
頭文件相關(guān)內(nèi)容
這里順便說下關(guān)于頭文件的幾個(gè)重要內(nèi)容。
1.防止頭文件被重復(fù)引用
這個(gè)問題對(duì)于老司機(jī)來說,可能不是什么問題,但很多新手卻沒搞明白是什么意思。
通常,在某xxx.h頭文件中,會(huì)有類似如下的一部分代碼:
“#”這是一個(gè)預(yù)處理指令,什么意思呢?
簡(jiǎn)單來說就是:如果沒有包含XXX.h頭文件,就包含;否則不包含(即不重復(fù)引用)。
2.全局(全部)頭文件 有些工程師喜歡把一個(gè)工程中所有的.h頭文件放在一個(gè)全局的頭文件(比如 global.h)中,然后,每個(gè).c源文件去引用這個(gè)(global.h)頭文件。
這樣有利也有弊: 利: 簡(jiǎn)單方便,不用擔(dān)心因?yàn)槁┑粢粋€(gè) .h 文件而引起錯(cuò)誤、警告;
弊: 只要修改一個(gè).h,工程就需要全局編譯,浪費(fèi)很多時(shí)間;
所以,我個(gè)人建議不使用這種全局頭文件(global.h)來管理頭文件。
這種做法只是方便了一時(shí),也不利于管理,在幾個(gè)源文件這種小項(xiàng)目中可能沒覺得什么。
但是,如果項(xiàng)目越來越大,特別幾十上百個(gè)源代碼,每個(gè)源文件代碼又比較大的情況下,你修改一個(gè) .h 文件,只能慢慢等待編譯。
在項(xiàng)目比較敢的時(shí)候,這種做法可能會(huì)使你心態(tài)奔潰。
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!