RealView MDK中使用內(nèi)聯(lián)函數(shù)時需要注意的問題
在MDK中使用關(guān)鍵字__inline時,除了執(zhí)行速度和占用空間和普通函數(shù)不一樣之外,還有以下與普通函數(shù)不一樣的地方:表現(xiàn)為,不能將其申明為外部函數(shù),即不能將__inline函數(shù)定義在一個外部文件中然后在引用的文件中申明為extern類型。
原因是MDK中使用的__inline函數(shù)時和標準C++中的inline函數(shù)有相同的語義。
在C++標準中,一個內(nèi)聯(lián)函數(shù)在用到它的每個解釋單元需要相同的定義,這樣看來只有內(nèi)部鏈接的才可能內(nèi)聯(lián)。將外部文件中的函數(shù)鏈接并內(nèi)聯(lián)似乎不可能,特別是外部函數(shù)是非內(nèi)聯(lián)的。為了在不同文件之間的函數(shù)可以內(nèi)聯(lián),必須:
2 將這些函數(shù)放在一個通用的頭文件中,例如foo.h;
2 將這些函數(shù)標記為extern __inline;
2 在需要該內(nèi)聯(lián)函數(shù)時,#include內(nèi)聯(lián)函數(shù)所在的頭文件。
當編譯器決定不內(nèi)聯(lián)某個函數(shù)時,在編譯鏈接之后該函數(shù)只有一個拷貝。注:根據(jù)筆者的實驗發(fā)現(xiàn)也可以將內(nèi)聯(lián)函數(shù)直接定義為__inline。
在MDK中如果將__inline函數(shù)申明為extern的話,在編譯時會通過,而在鏈接時會說這些函數(shù)沒定義。這點與Embest IDE不同。Embest IDE允許將內(nèi)聯(lián)函數(shù)在外部文件中定義,在引用的文件中,只須申明為extern類型即可通過編譯鏈接。
解決辦法,將內(nèi)聯(lián)函數(shù)定義在.h文件中,在需要引用的文件中包含該頭文件。這樣就可以調(diào)用頭文件中的內(nèi)聯(lián)函數(shù)了。并且能正確通過編譯、鏈接。
其實在MDK中AT91RM9200的標準庫中也是這么做的,AT91RM9200的標準庫有兩個.h文件DDAT91RM9200.h和lib_AT91RM9200.h,其中AT91RM9200.h中定義一些常量和外圍接口結(jié)構(gòu)體。其中l(wèi)ib_AT91RM9200.h中存放的就是庫函數(shù),其庫函數(shù)均為內(nèi)聯(lián)函數(shù)。
注:以上兩個頭文件存放的路徑為C:KeilARMINCAtmelRM9200。(其中MDK安裝路徑為C:Keil)
評論