Linux中有兩類函數(shù)庫,分別是靜態(tài)庫和動態(tài)庫。
靜態(tài)函數(shù)庫:
這類庫的名字一般是libxxx.a;利用靜態(tài)函數(shù)庫編譯成的文件比較大,因為整個函數(shù)庫的所有數(shù)據(jù)都會被整合進目標代碼中,他的優(yōu)點就顯而易見了,即編譯后的執(zhí)行程序不需要外部的函數(shù)庫支持,因為所有使用的函數(shù)都已經(jīng)被編譯進去了。當然這也會成為他的缺點,因為如果靜態(tài)函數(shù)庫改變了,那么你的程序必須重新編譯。
動態(tài)函數(shù)庫:
這類庫的名字一般是libxxx.so;相對于靜態(tài)函數(shù)庫,動態(tài)函數(shù)庫在編譯的時候并沒有被編譯進目標代碼中,你的程序執(zhí)行到相關函數(shù)時才調(diào)用該函數(shù)庫里的相應函數(shù),因此動態(tài)函數(shù)庫所產(chǎn)生的可執(zhí)行文件比較小。由于函數(shù)庫沒有被整合進你的程序,而是程序運行時動態(tài)的申請并調(diào)用,所以程序的運行環(huán)境中必須提供相應的庫。動態(tài)函數(shù)庫的改變并不影響你的程序,所以動態(tài)函數(shù)庫的升級比較方便。
linux系統(tǒng)有幾個重要的目錄存放相應的函數(shù)庫,如/lib /usr/lib。
下面來介紹linux靜態(tài)函數(shù)庫的創(chuàng)建和使用:
例程str_out.h str_out.c main.c:
str_out.h
#ifndef STR_OUT_H
#define STR_OUT_H
void str_out(const char* str);
#endif
str_out.c
#include
#include "str_out.h"
void str_out(const char* str){
printf("%s\n",str);
}
main.c
int main()
{
str_out("hello world");
return 0;
}
不管是靜態(tài)函數(shù)庫還是動態(tài)函數(shù)庫,都是由*.o目標文件生成。
所以先gcc -c str_out.c
靜態(tài)函數(shù)庫由ar命令創(chuàng)建
本例:ar -cr libstr_out.a str_out.o
-c create的意思
-r replace的意思,表示當插入的模塊名已經(jīng)在庫中存在,則替換同名的模塊。如果若干模塊中有一個模塊在庫中不存在,ar顯示一個錯誤消息,并不替換其他同名模塊。默認的情況下,新的成員增加在庫的結(jié)尾處,可以使用其他任選項來改變增加的位置。
到此靜態(tài)函數(shù)庫創(chuàng)建完畢。
使用方法:通過gcc -o out main.c -L. -lstr_out編譯main.c就會把靜態(tài)函數(shù)庫整合進out。
其中
-L指定靜態(tài)函數(shù)庫的位置供查找,注意L后面還有'.',表示靜態(tài)函數(shù)庫在本目錄下查找。
-l則指定了靜態(tài)函數(shù)庫名,由于靜態(tài)函數(shù)庫的命名方式是lib***.a,其中的lib和.a忽略。
根據(jù)靜態(tài)函數(shù)庫的特性,此處刪除libstr_out.a后out依然可以運行,因為靜態(tài)庫的內(nèi)容已經(jīng)整合進去了。
動態(tài)函數(shù)庫的創(chuàng)建和使用
gcc -shared -fPCI -o out main.c -L. -lstr_out
用該命令生成libstr_out.so 動態(tài)函數(shù)庫。
gcc -o out main.c
此時還不能立即./out,因為在動態(tài)函數(shù)庫使用時,會查找/usr/lib /lib目錄下的動態(tài)函數(shù)庫,而此時我們生成的庫不在里邊。
這個時候有好幾種方法可以讓他成功運行:
最直接最簡單的方法就是把libstr_out.so拉到/usr/lib 或/lib中去。
還有一種方法 export LD_LIBRARY_PATH=$(pwd)
另外還可以在/etc/ld.so.conf文件里加入我們生成的庫的目錄,然后/sbin/ldconfig。
/etc/ld.so.conf是非常重要的一個目錄,里面存放的是鏈接器和加載器搜索共享庫時要檢查的目錄,默認是從/usr/lib /lib中讀取的,所以想要順利運行,我們也可以把我們庫的目錄加入到這個文件中并執(zhí)行/sbin/ldconfig
另外還有個文件需要了解/etc/ld.so.cache,里面保存了常用的動態(tài)函數(shù)庫,且會先把他們加載到內(nèi)存中,因為內(nèi)存的訪問速度遠遠大于硬盤的訪問速度,這樣可以提高軟件加載動態(tài)函數(shù)庫的速度了。
本站僅提供存儲服務,所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權內(nèi)容,請
點擊舉報。