動態庫在程序編譯時并不會被連接到目標代碼中,而是在程序運行是才被載入,因此在程序運行時還需要動態庫存在。
程序1: hello.h #ifndef HELLO_H #define HELLO_H void hello(const char *name); #endif //HELLO_H 程序2: hello.c #include <stdio.h> void hello(const char *name){ PRintf("Hello %s!/n", name); } 程序3: main.c #include "hello.h" int main() { hello("everyone"); return 0; } 無論動態庫還是靜態庫都需要用到.o文件來生成,先編譯生成.o文件。gcc -c hello.c
1:創建靜態庫: 靜態庫文件名的命名規范是以lib為前綴,緊接著跟靜態庫名,擴展名為.a。例如:我們將創建的靜態庫名為myhello,則靜態庫文件名就是libmyhello.a。# ar cr libmyhello.a hello.o 使用靜態庫:只需要在你的源程序中加入包含你所需要使用到的函數的聲明(即包含頭文件),然后在gcc生成目標文件時候指明靜態庫就OK了(除非你包含的頭文件在/usr/include,庫文件在標準庫/usr/lib,/lib下,否則你得顯示指明他們的路徑)
gcc -o hello main.c -L. -lmyhello
./hello
Hello everyone 刪除靜態庫文件運行./hello,程序正常運行,說明靜態庫公用函數已經鏈接到目標文件。
2: 利用.o文件創建動態庫 動態庫文件擴展名為.so ./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory 哦!出錯了。快看看錯誤提示,原來是找不到動態庫文件libmyhello.so。程序在運行時,會在/usr/lib和/lib等目錄中查找需要的動態庫文件。若找到,則載入動態庫,否則將提示類似上述錯誤而終止程序運行。
如何找到生成的動態庫有3種方式: 1)把庫拷貝到/usr/lib和/lib目錄下。 (2)在LD_LIBRARY_PATH 環境變量中加上庫所在路徑。 例如動態庫 libhello.so 在/home/example/lib 目錄下: exportLDLIBRARYPATH= LD_LIBRARY_PATH:/home/example/lib (3) 修改/etc/ld.so.conf 文件,把庫所在的路徑加到文件末尾,并執行 ldconfig 刷新。這樣,加入的目錄下的所有庫文件都可見。 當靜態庫和動態庫同名時, gcc 命令將優先使用動態庫。
新聞熱點
疑難解答