链接器怎样使用静态库来解决符号引用
生活随笔
收集整理的這篇文章主要介紹了
链接器怎样使用静态库来解决符号引用
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
鏈接器在根據(jù)命令行中輸入的可重定位目標文件和靜態(tài)庫的順序從左到右的掃描這些文件。在這個掃描中,鏈接器會維護一個集合E,該集合包含了將來要被合并生產(chǎn)可執(zhí)行文件的所有可重定位目標文件;維護了一個集合U,包含了未解決的符號(只引用了但還沒有定義);還維護了一個集合D,包含被先前輸入文件定義的符號。開始的時候這三個集合都為空。
- 對于在命令行中的每個輸入文件f,鏈接器都會去判斷這個文件是目標文件還是靜態(tài)庫文件。如果是目標文件,鏈接器將f加入到集合E中,并將f中的已定義的符號和引用的符號分別加入到集合D和U中,并繼續(xù)處理下一個文件。
- ?如果f是靜態(tài)庫文件,鏈接器會掃描靜態(tài)庫中的目標文件m,如果m中定義的符號包含在集合U中,那么就將m加入到E中,然后將m中定義的符號和引用的符號加入到集合D和U中。然后繼續(xù)掃描靜態(tài)庫中的目標文件,直到U和D不再改變?yōu)橹埂?/span>
- 如果鏈接器完成了命令行中所有輸入文件的掃描,并且U為非空的,那么鏈接器會輸出錯誤然后終止。如果U為空,則合并和重定位E中的目標文件來生成可執(zhí)行文件。
看上面的處理過程其實有一個問題,那就是如果庫文件比引用庫文件的目標文件先處理,那么最后會導(dǎo)致后面處理的目標文件引用的符號最終無法被解析。如果后面輸入的庫依賴于前面已經(jīng)處理的庫也會出現(xiàn)同樣的問題,所以輸入文件的順序就變得很重要了,一般的規(guī)則是庫文件放在命令行的最后,引用另一個目標文件f的文件m,m要比f先輸入,如果m和f互相依賴,那么只有在f之后再輸入一個m文件,庫也是同樣的處理。
轉(zhuǎn)載于:https://www.cnblogs.com/chengxuyuancc/p/3479966.html
總結(jié)
以上是生活随笔為你收集整理的链接器怎样使用静态库来解决符号引用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: javascript和“主流大型语言”(
- 下一篇: [转]使用fragments