用weak symbol已經(jīng)比較長時間,這個功能對于c語言來說其實相當好用。不過最近遇到一個問題,如果一個靜態(tài)庫.o里的函數(shù)只有相對于weak的strong函數(shù)能被其他.o call到,那這個.o就不會被link到,最終始終會call到weak的那個function。
多次試驗和搜索,應該就是靜態(tài)庫的函數(shù)只有在要被用到的時候,才會被link,但weak symbol相對比較特殊,會先link到weak的function,然后再去找strong的function。因此strong的function實現(xiàn)在靜態(tài)庫里面,并且對應.o里函數(shù)也沒被其他.o call 到,整個靜態(tài)庫都不會被link進去,因此最后只會選weak function。
應對的方式
A:利用—whole-archive和—no-whole-archive強制靜態(tài)庫被link進去,這樣strong函數(shù)一定會被收到。缺點是如果lib之間有同名function會打出build error
B:和A類似,利用link選項-u強制某個function被link,但lib和function較多時不好用
最后附上相關一些ld option及簡單說明:
—start-group —end-group》resolve circular dependency,處理gcc .o之間有依賴關系時,因為link順序引起build error
—whole-archive —no-whole-archive》在這兩個option之間,會把靜態(tài)庫的symbol提前l(fā)ink進來,平常只有被call到在會link進去
link時的-u symbol_name強制keep該symbol