舉例分析Linux動態庫和靜態庫

2021-06-03 11:13:52 字數 2976 閱讀 5788

函式庫分為靜態庫和動態庫兩種。建立linux靜態庫和linux動態庫和使用它們在這裡將以舉例的形式詳述一下。靜態庫在程式編譯時會被連線到目標**中,程式執行時將不再需要該靜態庫。動態庫在程式編譯時並不會被連線到目標**中,而是在程式執行是才被載入,因此在程式執行時還需要動態庫存在。

第1步:編輯得到舉例的程式——hello.h、hello.c和main.c;

hello.h(見程式1)為該函式庫的標頭檔案。

hello.c(見程式2)是函式庫的源程式,其中包含公用函式hello,該函式將在螢幕上輸出"hello ***!".

main.c(見程式3)為測試庫檔案的主程式,在主程式中呼叫了公用函式hello.

程式1: hello.h #ifndef hello_h #define hello_h void hello(const char *name);#endif //hello_h

程式2: hello.c #include void hello(const char *name)

程式3: main.c #include "hello.h" int main()

第2步:將hello.c編譯成。o檔案

無論靜態庫,還是動態庫,都是由。o檔案建立的。因此,我們必須將源程式hello.c通過gcc先編譯成。o檔案。在系統提示符下鍵入以下命令得到hello.o檔案。

# gcc -c hello.c

第3步:由。o檔案建立靜態庫

靜態庫檔名的命名規範是以lib為字首,緊接著跟靜態庫名,擴充套件名為。a.例如:我們將建立的靜態庫名為myhello,則靜態庫檔名就是libmyhello.a.在建立和使用靜態庫時,需要注意這點。建立靜態庫用ar命令。在系統提示符下鍵入以下命令將建立靜態庫檔案libmyhello.a.

# ar cr libmyhello.a hello.o

第4步:在程式中使用靜態庫

靜態庫製作完了,如何使用它內部的函式呢?只需要在使用到這些公用函式的源程式中包含這些公用函式的原型宣告,然後在用gcc命令生成目標檔案時指明靜態庫名,gcc將會從靜態庫中將公用函式連線到目標檔案中。注意,gcc會在靜態庫名前加上字首lib,然後追加副檔名。a得到的靜態庫檔名來查詢靜態庫檔案。在程式3:main.c中,我們包含了靜態庫的標頭檔案hello.h,然後在主程式main中直接呼叫公用函式hello.下面先生成目標程式hello,然後執行hello程式看看結果如何。

# gcc -o hello main.c -l. -lmyhello # ./hello hello everyone!

我們刪除靜態庫檔案試試公用函式hello是否真的連線到目標檔案 hello中了。

# rm libmyhello.a rm: remove regular file `libmyhello.a'? y # ./hello hello everyone!

#程式照常執行,靜態庫中的公用函式已經連線到目標檔案中了。我們繼續看看如何在linux中建立動態庫。我們還是從。o檔案開始。

第5步:由。o檔案建立動態庫檔案

動態庫檔名命名規範和靜態庫檔名命名規範類似,也是在動態庫名增加字首lib,但其擴充套件名為。so.例如:我們將建立的動態庫名為myhello,則動態庫檔名就是libmyhello.so.用gcc來建立動態庫。在系統提示符下鍵入以下命令得到動態庫檔案libmyhello.so.

# gcc -shared -fpci -o libmyhello.so hello.o

第6步:在程式中使用動態庫

在程式中使用動態庫和使用靜態庫完全一樣,也是在使用到這些公用函式的源程式中包含這些公用函式的原型宣告,然後在用gcc命令生成目標檔案時指明動態庫名進行編譯。我們先執行gcc命令生成目標檔案,再執行它看看結果。

# gcc -o hello main.c -l. -lmyhello # ./hello./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: no such file or directory #哦!出錯了。快看看錯誤提示,原來是找不到動態庫檔案libmyhello.so.程式在執行時,會在/usr/lib和/lib等目錄中查詢需要的動態庫檔案。若找到,則載入動態庫,否則將提示類似上述錯誤而終止程式執行。我們將檔案libmyhello.so複製到目錄/usr/lib中,再試試。

# mv libmyhello.so /usr/lib # ./hello hello everyone!

#成功了。這也進一步說明了動態庫在程式執行時是需要的。

我們回過頭看看,發現使用靜態庫和使用動態庫編譯成目標程式使用的gcc命令完全一樣,那當靜態庫和動態庫同名時,gcc命令會使用哪個庫檔案呢?抱著對問題必究到底的心情,來試試看。先刪除 除。c和。h外的 所有檔案,恢復成我們剛剛編輯完舉例程式狀態。

# rm -f hello hello.o /usr/lib/libmyhello.so # ls hello.c hello.h main.c #在來建立靜態庫檔案libmyhello.a和動態庫檔案libmyhello.so.

# gcc -c hello.c # ar cr libmyhello.a hello.o # gcc -shared -fpci -o libmyhello.so hello.o # ls hello.c hello.h hello.o libmyhello.a libmyhello.so main.c #通過上述最後一條ls命令,可以發現靜態庫檔案libmyhello.a和動態庫檔案libmyhello.so都已經生成,並都在當前目錄中。然後,我們執行gcc命令來使用函式庫myhello生成目標檔案hello,並執行程式 hello.

# gcc -o hello main.c -l. -lmyhello # ./hello./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: no such file or directory #從程式hello執行的結果中很容易知道,當linux靜態庫和linux動態庫同名時, gcc命令將優先使用動態庫。

Linux動態庫和靜態庫基礎

example hello.c hello.h main.c 1.靜態庫 gcc c hello.c ar cr libhello.a hello.o 引用庫 lhello 2.動態庫 gcc c hello.c gcc shared fpci o libhello.so hello.o 引用庫 l...

動態庫和靜態庫

本文主要解決以下幾個問題 1 為什麼要使用庫?2 庫的分類 3 建立自己的庫 或許大家對自己初學linux時的情形仍記憶尤新吧。如果沒有乙個能較好的解決依賴關係的包管理器,在linux下安裝軟體將是一件及其痛苦的工作。你裝a包時,可能會提示你要先裝b包,當你費盡心力找到b包時,可能又會提示你要先安裝...

動態庫和靜態庫

先抄一段 windows下的動態庫和靜態庫區別解釋,其實linux下意義一樣的,不過字尾名有些區別 靜態庫 在編譯的時候載入生成目標檔案,在執行時不用載入庫,在執行時對庫沒有依賴性。動態庫 在目標檔案執行時載入,手動載入,且對庫有依賴性。兩者區別 一,靜態庫的使用需要 1 包含乙個對應的標頭檔案告知...