虛擬機器:GCC共享庫在連線時的搜尋位置和優選次序

农民小工程师發表於2024-07-29

假設有兩個相同的共享庫,一個在標準的共享庫搜尋目錄(/lib/i386-linux-gnu), 一個在非標準目錄(/home/charles/tmp):

虛擬機器:GCC共享庫在連線時的搜尋位置和優選次序

在/home/charles/tmp下有個測試程式main.c, 呼叫共享庫裡的函式。

用如下的命令編譯:虛擬機器:GCC共享庫在連線時的搜尋位置和優選次序

用ldd看一下link的共享庫:

虛擬機器:GCC共享庫在連線時的搜尋位置和優選次序

可以看出,雖然我們指定了 要使用 /home/charles/tmp下的庫,但實際上用的還是標準搜尋路徑下的庫。

換句話說,GNU ld 優選搜尋標準路徑下的檔案,然後才是 -L指定的

現在執行

export LD_LIBRARY_PATH=/home/charles/tmp

虛擬機器:GCC共享庫在連線時的搜尋位置和優選次序

可見, LD_LIBRARY_PATH指定的路徑法務時刻優選於系統標準目錄。

最後嘗試一下如下的方法:

gcc main.c -wl,-rpath,/home/charles/tmp -g -o main -lshared

或者:

gcc main.c -Wl,-rpath /home/charles/tmp -g -o main -lshared

虛擬機器:GCC共享庫在連線時的搜尋位置和優選次序

最後,總結一下,共享庫的搜尋順序(按照優先次序):

1) LD_LIBRARY_PATH指定的目錄

2) rpath指定的路徑。

rpath指定的路徑同時被寫進了二進位制檔案裡面。

p$ readelf -d main | grep rpath

0x0000000f (RPATH) Library rpath: [/home/charles/tmp]

3)系統標準路徑

這包括 /lib, /usr/lib, /usr/local/lib以及在/etc/ld.conf https://www.jiwenlaw.com/裡面指定的路徑。

相關文章