精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

程序運行時,是怎么找到動態庫的?

開發 后端
了解動態庫的搜索路徑,可以在開發中很好的幫助你定位找不到庫的問題,同時LD_DEBUG環境變量也能夠很好的幫助你調試,例如查看庫搜索的路徑,顯示符號的查找過程等等。

[[387528]]

我們隨便開發一個C/C++程序,都很大程度不可避免的需要用到動態庫:

  1. // 來源:公眾號【編程珠璣】 
  2. #include <stdio.h> 
  3. int main() 
  4.     printf("hello,編程珠璣\n"); 
  5.     return 0; 

編譯并查看使用到的動態庫:

  1. $ gcc -o main main.c 
  2. $ ldd main 
  3.     linux-vdso.so.1 (0x00007ffdf8fdf000) 
  4.     libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f1f8535e000) 
  5.     /lib64/ld-linux-x86-64.so.2 (0x00007f1f85951000) 

從ldd命令的結果我們可以看到main程序依賴了哪些動態庫,并且在哪個路徑。那么你有沒有想過,動態庫的路徑是怎么找到的,查找順序又是怎樣的呢?

準備動態庫

在此之前如果你還沒有對動態庫有一個基本的了解的話,建議你閱讀《淺談靜態庫和動態庫》或其他相關資料。為了說明后面的問題,這里我們先創建一個簡單的動態庫,你也可以參考《手把手教你制作動態庫》:

  1. // test.c 
  2. //來源:公眾號【編程珠璣】 
  3. #include <stdio.h> 
  4. #include "test.h" 
  5. #include "test1.h" 
  6. void test() 
  7.     printf("I am test;hello,編程珠璣\n"); 
  8.     test1(); 
  9.  
  10. // test.h 
  11. void test(); 
  12.  
  13.  
  14. //test1.c 
  15. #include <stdio.h> 
  16. #include "test1.h" 
  17. void test1() 
  18.     printf("test1,needed by test\n"); 
  19. // test1.h 
  20. void test1(); 

分別制作動態庫libtest.so和libtest1.so,這在后面的示例中會用到:

  1. $ gcc test1.c -fPIC -shared -o libtest1.so 
  2. $ gcc test.c -fPIC -shared -o libtest.so -L. -ltest1 

這樣你在當前目錄下就會看到有一個libtest.so和libtest1.so文件生成了,其中litest.so依賴libtest.so

注意,由于libtest.so依賴libtest1.so,這里用-L指定了要鏈接的test1的路徑,因此我們看到:

  1. $ ldd libtest.so 
  2.     linux-vdso.so.1 (0x00007ffd1bbca000) 
  3.     libtest1.so => not found 
  4.     libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f9f1d0ae000) 
  5.     /lib64/ld-linux-x86-64.so.2 (0x00007f9f1d6a1000) 

從這里可以看出libtest是依賴libtest1庫的,但是特別注意到,libtest1.so指向的是not found,這會有什么影響嗎?我們后面就會看到。

鏈接時查找路徑

我們都知道,在編譯成可執行文件前,鏈接器鏈接動態庫也是需要查找動態庫路徑的,否則怎么鏈接上指定的動態庫呢?那么這個順序又是怎樣的呢?

首先會查找的會是編譯時鏈接的路徑。修改前面的main.c,讓它調用libtest.so中的test函數:

  1. // 來源:公眾號【編程珠璣】 
  2. #include <stdio.h> 
  3. #include "test.h" 
  4. int main() 
  5.     test(); // 調用libtest.so中的test函數 
  6.     return 0; 

編譯鏈接:

  1. $ gcc -o main main.c -I ./ -L./ -ltest -ltest1 

完美編譯過。除此之外,如果我們把libtest.so和libtest1.so都移到/usr/lib下面,我們發現,即便不用-L也能編譯過了:

  1. $ gcc -o main main.c -I ./  -ltest -ltest1 

這里需要說明的是,我們通過-L./來指定搜索庫的路徑,由于libtest.so依賴libtest1.so,因此在編譯鏈接時,也需要鏈接上test1。

小結

從上面的內容可以看到,在鏈接時,我們通過-L參數搜索要鏈接的庫路徑,但是這個路徑信息不會寫到ELF文件中,因此你會通過ldd命令看到not found,而通過-rpath可以指定鏈接時的搜索路徑,這個信息會寫入到ELF文件中,最終看到的結果是,由于libtest.so依賴libtest1.so,所以其他程序依賴libtest.so時,會自動從寫入ELF的rpath中搜索它依賴的其他庫,因此只需要鏈接libtest即可,例如:

在制作庫libtest1.so時,加上-rpath-link選項:

  1. $ gcc test.c -fPIC -shared -o libtest.so -L. -ltest1 -Wl,-rpath-link $(pwd) 

在編譯main的時候,就不需要特意指定鏈接libtest1.so

  1. $ gcc -o main main.c -L ./ -ltest 

只需要鏈接libtest.so,其依賴的libtest1.so也鏈接進來了。

當然了,如果-L指定的路徑沒有呢,它還會去查找其他地方,否則依賴的系統庫怎么找到呢?總結大致順序如下:

  • -L指定鏈接路徑
  • 對于依賴庫中依賴的搜索順序通過-rpath-link或-rpath選項查找(后面會提到)
  • gcc默認鏈接路徑(gcc --print-search-dir | grep libraries 查看)
  • 鏈接器配置的查找路徑(ld -verbose | grep SEARCH_DIR查看)

針對具體的系統或鏈接器,可能有些差異,但是大致如此。

運行時查找路徑

雖然前面編譯成功了,但是我們運行看看,發現運行失敗了。

  1. $ ./main 
  2. ./main: error while loading shared libraries: libtest.so: cannot open shared object file: No such file or directory 

其實我們用ldd命令看一下也能看到:

  1. linux-vdso.so.1 (0x00007ffcd566e000) 
  2.     libtest.so => not found 
  3.     libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f356d1f6000) 
  4.     /lib64/ld-linux-x86-64.so.2 (0x00007f356d7e9000) 

LD_PRELOAD環境變量

這個環境變量在介紹《性能優化-使用高效內存分配器》中的時候,也有提到,用來做測試非常方便,同樣的,這種方式也最好僅僅只是用于測試,因為它的優先級非常高,并且影響全局。使用也很簡單:

  1. $ export LD_PRELOAD=./libtest.so 
  2. $ ./main 

為了避免影響后面的驗證,這里取消設置該環境變量:

  1. unset LD_PREALOD 

查找rpath路徑

上面的情況是找不到動態庫,那么它首先會去rpath指定路徑去查找,這需要在編譯時指定:

  1. $ gcc test.c -fPIC -shared -o libtest.so -L. -ltest1 -Wl,-rpath $(pwd) 
  2. $ gcc -o main main.c -L . -ltest -Wl,-rpath $(pwd) 
  3. $ ./main 
  4. I am test;hello,編程珠璣 
  5. test1,needed by test 

也就是說,如果我們編譯時指定了路徑,就可以找到了,但是這些信息被寫入到了ELF文件中。

LD_LIBRARY_PATH環境變量

另外也可以通過這個環境變量來設置要搜索庫的路徑。

  1. $ gcc -o main main.c -L . -ltest 
  2. $ export LD_LIBRARY_PATH=./ 
  3. $ ./main 

這樣運行也是沒有問題的。

同樣,為了避免對后面測試產生影響,取消設置該環境變量:

  1. unset LD_LIBRARY_PATH 

/etc/ld.so.conf中的路徑

我的機器上這個文件的內容如下:

  1. $ cat /etc/ld.so.conf 
  2. include /etc/ld.so.conf.d/*.conf 
  3. $ ls /etc/ld.so.conf.d/ 
  4. fakeroot-x86_64-linux-gnu.conf  libc.conf  x86_64-linux-gnu.conf 

所以它實際指的是/etc/ld.so.conf.d/目錄下所有conf路徑包含路徑,打開其中一個libc.conf,它里面包含的路徑為:

  1. $ /usr/local/lib 

既然如此,我們把前面的libtest.so復制到該目錄下(可能需要sudo權限):

  1. $ sudo cp libtest.so /usr/local/lib 
  2. $ sudo ldconfig 
  3. $ ./main 
  4. I am test;hello,編程珠璣 
  5. test1,needed by test 

注意,這里拷貝完成后,需要執行ldconfig,它會更新相應的共享庫,以便可執行程序能夠找到。實際上,執行完成后,你確實就能在/etc/ld.so.cache文件中找到:

  1. $ grep -a libtest.so /etc/ld.so.cache 

同樣,為了影響后面測試,記得刪除:

  1. rm /usr/local/lib/libtest.so 

實際上這里是先從/etc/ld.so.cache中的路徑查找,然后再從ld.so.conf的路徑中查找。后面我們可以通過命令看到。

/usr/lib,/lib/

當然了,如果以上路徑都沒有,最終還會在lib或/usr/lib下找,為了驗證,我們將庫拷貝到/lib目錄下

  1. $ cp libtest.so /lib 
  2. $ ./main 
  3. I am test;hello,編程珠璣 
  4. test1,needed by test 

同樣能正常運行。

小結

小結一下,動態庫的搜索順序如下:

  • LD_PRELOAD環境變量指定庫路徑
  • -rpath鏈接時指定路徑
  • LD_LIBRARY_PATH環境變量設置路徑
  • /etc/ld.so.conf配置文件指定路徑
  • 默認共享庫路徑,/usr/lib,lib

以上這些查找路徑你很容易來驗證它們的優先級,簡單的做法就是這幾個位置分別放置同名不同作用的庫,來看看它到底先使用哪個路徑下的庫,可自行嘗試。

LD_DEBUG

這個環境通常用來調試。例如,查看整個裝載過程:

  1. $ LD_DEBUG=files ./main 

或者查看依賴的庫的查找過程:

  1. $ LD_DEBUG=libs ./main 
  2.       3557:    find library=libtest.so [0]; searching 
  3.       3557:     search cache=/etc/ld.so.cache 
  4.       3557:      trying file=/usr/local/lib/libtest.so 

另外還可以顯示符號的查找過程:

  1. $ LD_DEBUG=symbols ./main 

總結

了解動態庫的搜索路徑,可以在開發中很好的幫助你定位找不到庫的問題,同時LD_DEBUG環境變量也能夠很好的幫助你調試,例如查看庫搜索的路徑,顯示符號的查找過程等等。

 

雖然程序運行能夠有多種途徑獲取動態庫路徑,但是并不是每種方式都合適,有的方式甚至完全不該用,但這超出了本文的討論范圍了。有興趣的也可以點擊閱文原文,查看《Why LD_LIBRARY_PATH is bad》

 

責任編輯:武曉燕 來源: 編程珠璣
相關推薦

2021-09-11 15:38:23

容器運行鏡像開放

2023-07-28 10:42:43

2019-11-26 09:00:29

動態庫靜態庫運行時庫

2015-07-20 15:44:46

Swift框架MJExtension反射

2011-08-19 15:05:29

異常處理

2024-03-21 09:15:58

JS運行的JavaScrip

2010-01-27 14:14:48

C++程序運行時間

2020-12-07 13:31:43

GoMutex開發者

2019-07-12 09:30:12

DashboardDockerDNS

2024-01-29 08:07:42

FlinkYARN架構

2023-08-27 21:07:02

2023-08-21 09:37:57

MySQL工具MariaDB

2021-08-18 08:32:09

代碼運行時間示波器

2024-03-20 10:46:00

云原生容器

2022-01-19 08:50:53

設備樹Linux文件系統

2023-01-03 09:10:21

2013-11-26 16:49:55

Android開發運行時KitKat

2009-02-10 09:03:59

動態語言CLRVB.NET

2021-08-27 00:21:19

JSJust源碼

2023-08-29 08:20:35

Kubernete跨云容器
點贊
收藏

51CTO技術棧公眾號

精品视频1区2区3区| 国产亚洲欧美日韩日本| 欧美激情国产日韩精品一区18| 中国老熟女重囗味hdxx| 涩涩视频在线| 国产精品家庭影院| 国产青春久久久国产毛片| 波多野结衣视频观看| 亚洲九九在线| 亚洲美女性生活视频| 99理论电影网| 久久精品ww人人做人人爽| 国产精品18在线| 成人午夜网址| 欧美日韩一区高清| 日韩a∨精品日韩在线观看| 国产理论电影在线观看| 国产一区在线看| 国产99久久久欧美黑人| 欧美日韩在线国产| 日韩欧美电影| 亚洲精品99999| 亚洲精品在线网址| 日韩中文影院| 亚洲成人午夜电影| 国产高潮呻吟久久久| 久蕉在线视频| 99精品国产一区二区三区不卡| 国产一区二区在线免费| 麻豆精品久久久久久久99蜜桃| 欧美激情日韩| 日韩视频永久免费观看| 国产中年熟女高潮大集合| 最新精品在线| 欧美一区二区日韩一区二区| 国内国产精品天干天干| 欧美成人黑人| 欧美午夜视频一区二区| 丁香六月激情婷婷| 污视频网站在线免费| 亚洲天堂精品视频| 伊人久久99| 91最新在线| 欧美国产乱子伦| 污视频在线免费观看一区二区三区| 特黄aaaaaaaaa真人毛片| 国产不卡在线视频| 亚洲www视频| 国产精品毛片久久久久久久av| 日本麻豆一区二区三区视频| 国产精品 欧美在线| 五月激情六月丁香| 国产欧美成人| 国产91对白在线播放| 欧美一级特黄视频| 亚洲视频1区| 青青草99啪国产免费| 黄色av一级片| 日本在线播放一区二区三区| 国产精品r级在线| 日韩一级片中文字幕| 日韩精品五月天| 国产精品一区二区三区成人| 中文字幕在线观看1| 久久爱另类一区二区小说| 国产欧美精品在线播放| 国产精品久久久久久免费| 久久99国产精品麻豆| 91免费国产网站| 国产三级视频在线播放| 国产精品综合av一区二区国产馆| 51精品国产人成在线观看| www.热久久| 成人免费毛片嘿嘿连载视频| 久久精品一二三区| 国产中文在线观看| 国产精品理论在线观看| 国产精品8888| 丝袜老师在线| 欧美网站一区二区| 91丨九色丨蝌蚪| 97久久超碰| 亚洲精品黄网在线观看| 蜜桃av乱码一区二区三区| 日韩精品免费| 欧美激情久久久久久| 美女又爽又黄免费视频| 久久国产麻豆精品| av一区二区三区在线观看| 同心难改在线观看| 国产精品福利一区二区三区| 美女av免费观看| 在线手机中文字幕| 欧美日韩不卡一区二区| aaa黄色大片| 禁断一区二区三区在线| 美女视频久久黄| 99精品在线播放| 国产一区不卡在线| 久久久久久99| 八戒八戒神马在线电影| 欧美性xxxxxxxxx| 亚洲欧美日韩网站| 国产传媒欧美日韩成人精品大片| 菠萝蜜影院一区二区免费| 西西44rtwww国产精品| 久久国产精品99精品国产| 精品国产一区二区三区日日嗨| av在线1区2区| 调教+趴+乳夹+国产+精品| 在线观看岛国av| 一区二区导航| 欧美黄色成人网| 中文字幕日韩第一页| av不卡免费在线观看| 香蕉精品视频在线| 成人黄色免费短视频| 精品福利一区二区三区免费视频| 潮喷失禁大喷水aⅴ无码| 亚洲精选国产| 999在线观看免费大全电视剧| 国产小视频免费在线观看| 午夜久久久久久电影| 亚洲三级在线观看视频| 国产日产精品_国产精品毛片| 欧美劲爆第一页| 国产裸体无遮挡| 国产精品久久三区| 日本a√在线观看| 亚洲另类av| 91产国在线观看动作片喷水| 亚洲黄色小说网址| 亚洲精品成人精品456| 九色porny自拍| 成人久久久久| 国产精品人人做人人爽| 激情小视频在线| 狠狠做深爱婷婷久久综合一区| 精品国产aⅴ一区二区三区东京热| 日韩精品电影| 国产欧美精品一区二区三区介绍| 福利视频在线播放| 在线观看免费成人| 一道本在线观看| 久久久成人网| 欧美极品一区二区| 欧美性xxx| 亚洲视频在线视频| 免费黄色片视频| 久久在线观看免费| 日韩中文字幕免费在线| 美女精品一区最新中文字幕一区二区三区 | 中文字幕永久在线观看| 国产女主播一区| www.天天射.com| 日韩欧美午夜| 91久久精品美女高潮| 91亚洲天堂| 亚洲国产成人爱av在线播放| 日本免费观看视| 久久久久久久久久久黄色| 精品久久久久久久免费人妻| 亚洲精品进入| 国产精品你懂得| 免费黄色网页在线观看| 日韩一级片在线观看| 黄色av网址在线播放| h视频久久久| 7m第一福利500精品视频| 久草视频在线看| 欧美日本精品一区二区三区| 日韩成人短视频| 成人动漫中文字幕| 日韩精品一区二区三区色欲av| 少妇精品久久久| 成人精品网站在线观看| 毛片大全在线观看| 日韩电影网在线| 欧美成人一区二区视频| 亚洲男同1069视频| 精品国产av色一区二区深夜久久| 久久国产日本精品| 亚洲欧美一二三| 青青一区二区| 成人国产精品免费视频| 黑人极品ⅴideos精品欧美棵| 日韩精品亚洲视频| 国产一区二区三区四区视频| 亚洲最大色网站| 亚洲av毛片基地| 成人午夜又粗又硬又大| 久久久国产欧美| 欧美精品日本| 偷拍视频一区二区| 国产成人tv| 国产日韩欧美黄色| 欧美13videosex性极品| 久久久国产精彩视频美女艺术照福利| 日批视频免费播放| 欧美精品免费视频| 国产精品一区无码| 一级精品视频在线观看宜春院| 亚洲天堂视频一区| 国产成人免费网站| 黄色永久免费网站| 欧美亚洲专区| 国产精品国三级国产av| 日韩欧美视频| 欧美日韩亚洲一区二区三区在线观看 | 亚洲一本视频| 久久av秘一区二区三区| 伊人久久大香线蕉无限次| 成人午夜在线视频一区| 成人在线爆射| 97福利一区二区| 国产成人午夜| 丝袜美腿亚洲一区二区| 手机看片1024国产| 日韩视频永久免费| 国产精品福利电影| 色老汉一区二区三区| 国产 欧美 日韩 在线| 亚洲综合清纯丝袜自拍| 日本一级片免费| 日本一区二区视频在线| 久久精品老司机| k8久久久一区二区三区| 四虎永久免费观看| 国产精品正在播放| 爽爽爽在线观看| 蜜桃传媒麻豆第一区在线观看| 日韩av资源在线| 国产精品一二| av免费观看网| 国产一级一区二区| 欧美日韩成人免费视频| 亚洲经典自拍| 热99这里只有精品| 一区二区三区成人精品| 国产午夜福利100集发布| 尹人成人综合网| 97干在线视频| 亚洲国产一区二区三区高清| 无码专区aaaaaa免费视频| 亚洲国产日韩欧美一区二区三区| 欧美精品卡一卡二| 国产情侣一区| 日本精品免费在线观看| 丝袜国产日韩另类美女| 日韩精品一区二区三区色欲av| 日韩主播视频在线| 九色porny自拍| 国产一区二区电影| 人妻换人妻a片爽麻豆| 99在线视频精品| 亚洲av无码国产精品麻豆天美| 久久精品免费在线观看| 少妇无套高潮一二三区| 中文一区二区在线观看| 欧美三级黄色大片| 亚洲一区二区三区视频在线播放| 国产乡下妇女做爰视频| 欧美日韩综合视频| 国产精品国产精品国产| 7777精品伊人久久久大香线蕉经典版下载 | 久久婷婷久久| 一本岛在线视频| 国产成人综合在线播放| 在线观看国产网站| 中文字幕巨乱亚洲| 久久久香蕉视频| 欧美性极品xxxx娇小| 一级α片免费看刺激高潮视频| 欧美一区二区三区色| 特黄aaaaaaaaa真人毛片| 一区二区三区在线播放欧美| 国产在线1区| 97视频在线观看视频免费视频| 综合在线影院| 91久久精品美女高潮| 日本国产精品| 四虎影院一区二区| 一本久道久久综合狠狠爱| 超碰av在线免费观看| 国产乱码精品一区二区三区忘忧草 | 亚洲成aⅴ人片久久青草影院| 亚洲精品一区国产精品| 韩国av一区| 青青青在线视频免费观看| 国产精品亚洲午夜一区二区三区 | 91国内在线视频| 久久精品资源| 好吊色欧美一区二区三区 | 中文字幕日韩三级| 欧美mv和日韩mv国产网站| 国产小视频在线观看| 欧美黑人极品猛少妇色xxxxx| 欧美极度另类| 国产精品国产亚洲精品看不卡15| 久草成人资源| 国产精品一色哟哟| 久久99精品久久久久婷婷| 成人无码www在线看免费| 亚洲美女免费视频| 中文字幕av免费观看| 亚洲精品国产品国语在线| 在线视频中文字幕第一页| 国产精品久久久久久久久久免费 | 韩日欧美一区二区三区| 国产精品jizz| 亚洲国产成人精品视频| 国产精品嫩草影院精东| 一本一本久久a久久精品综合小说 一本一本久久a久久精品牛牛影视 | 成入视频在线观看| 91在线国产电影| 久久久综合色| 欧美性猛交久久久乱大交小说| 成人深夜在线观看| 日本中文字幕免费在线观看| 在线亚洲一区二区| 你懂的视频在线播放| 久久人人97超碰精品888| 亚洲啊v在线免费视频| 正在播放亚洲| 麻豆国产精品官网| 亚洲欧美va天堂人熟伦| 色哟哟亚洲精品| 欧美少妇另类| 欧美亚洲在线视频| 日韩中文av| 久激情内射婷内射蜜桃| caoporen国产精品视频| 国产亚洲第一页| 欧美成人伊人久久综合网| wwwav在线| 99国精产品一二二线| 欧美久久综合| ass极品水嫩小美女ass| 亚洲精品日产精品乱码不卡| 国产麻豆免费视频| 欧美成年人视频| 久久三级中文| 日韩精品一区二区免费| 国产成人亚洲精品狼色在线 | 成人jjav| 国产一区二区视频在线观看| 国产精品7m凸凹视频分类| 九九热免费在线观看| 亚洲视频一区在线| 国产极品久久久| 久久久久久久久亚洲| 成人直播在线观看| 欧美日韩一道本| 26uuu久久综合| 日韩精品一区二区亚洲av观看| 亚洲女成人图区| av亚洲一区| 免费看av软件| 国产99久久精品| 久久一区二区三区视频| 亚洲男人的天堂在线| 91国内外精品自在线播放| 影音先锋在线亚洲| 国产精品羞羞答答xxdd| 日本亚洲色大成网站www久久| 亚洲精品一区二区三区不| 欧美精品资源| 中文字幕超清在线免费观看| 粉嫩嫩av羞羞动漫久久久 | 国产农村妇女精品一区二区| 国产精品高清无码在线观看| 欧美日韩精品福利| 青春草视频在线观看| 欧美高清性xxxxhd| 美女看a上一区| 久久久久久久久久久网| 亚洲精品自在久久| 中文字幕综合| 3d动漫一区二区三区| 国产欧美一区视频| 国产黄色免费大片| 国产不卡在线观看| 中文字幕一区二区三区久久网站 | 亚洲欧美成人vr| 国内国产精品天干天干| 午夜精品一区二区三区电影天堂| gogogo高清在线观看免费完整版| 亚洲一区免费网站| 美女网站久久| 九九久久免费视频| 亚洲无亚洲人成网站77777| 国产精品麻豆| 日本毛片在线免费观看| 亚洲三级在线免费| 视频午夜在线| 999在线免费观看视频| 青娱乐精品视频在线| 国产一级视频在线播放| 在线观看日韩欧美| 人人精品视频|