我們通常把一些公用函式製作成函式庫,供其它程式使用。
函式庫分為靜態庫和動態庫兩種。
靜態庫在程式編譯時會被連線到目標**中,程式執行時將不再需要該靜態庫。
動態庫在程式編譯時並不會被連線到目標**中,而是在程式執行是才被載入,因此在程式執行時還需要動態庫存在。
本文主要通過舉例來說明在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
我們執行ls命令看看是否生存了 hello.o 檔案。
# ls
hello.c hello.h hello.o main.c
在 ls 命令結果中,我們看到了 hello.o 檔案,本步操作完成。
第3步:由.o檔案建立靜態庫;
靜態庫檔名的命名規範是以 lib 為字首,緊接著跟靜態庫名,擴充套件名為 .a。例如:我們將建立的靜態庫名為 myhello,則靜態庫檔名就是 libmyhello.a。在建立和使用靜態庫時,需要注意這點。建立靜態庫用 ar 命令。
在系統提示符下鍵入以下命令將建立靜態庫檔案 libmyhello.a。
# ar cr libmyhello.a hello.o
我們同樣執行ls命令檢視結果:
# ls
hello.c hello.h hello.o libmyhello.a main.c
第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
# ./hello
hello everyone!
程式照常執行,靜態庫中的公用函式已經連線到目標檔案中了。
第5步:由 .o 檔案建立動態庫檔案;
動態庫檔名命名規範和靜態庫檔名命名規範類似,也是在動態庫名增加字首 lib,但其擴充套件名為 .so。
例如:我們將建立的動態庫名為 myhello,則動態庫檔名就是 libmyhello. so。用 gcc 來建立動態庫。
在系統提示符下鍵入以下命令得到動態庫檔案 libmyhello. so。
# gcc -shared -fpci -o libmyhello.so hello.o
我們照樣使用ls命令看看動態庫檔案是否生成。
# ls
hello.c hello.h hello.o libmyhello. so main.c
第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 執行的結果中很容易知道,當靜態庫和動態庫同名時, gcc 命令將優先使用動態庫。 linux下的C語言開發(靜態庫)
在我們編寫軟體的過程當中,少不了需要使用別人的庫函式。因為大家知道,軟體是乙個協作的工程。作為個人來講,你不可能乙個人完成所有的工作。另外,網路上一些優秀的開源庫已經被業內廣泛接受,我們也沒有必要把時間浪費在這些重複的工作上面。既然說到了庫函式,那麼一般來說庫函式分為兩種方式 靜態庫和動態庫。兩者的...
Linux下C語言使用openssl庫進行加密
在這裡插一小節加密的吧,使用openssl庫進行加密。使用md5加密 我們以乙個字串為例,新建乙個檔案filename.txt,在檔案內寫入hello 然後在linux下可以使用命令md5sum filename.txt計算md5值 b1946ac92492d2347c6235b4d2611184 ...
linux下的C語言開發(靜態庫 動態庫)
動態鏈結庫不是linux獨有的特性,在windows下面也存在這樣的特性。一般來說,windows下面的動態連線庫是以 dll作為結尾的,而linux下面的動態連線庫是以 so結尾的。和靜態鏈結庫相比,動態連線庫可以共享記憶體資源,這樣可以減少記憶體消耗。另外,動態連線是需要經過作業系統載入器的幫助...