靜態庫在linux環境中, 使用ar命令建立靜態庫檔案.如下是命令的選項:
d -----從指定的靜態庫檔案中刪除檔案
m -----把檔案移動到指定的靜態庫檔案中
p -----把靜態庫檔案中指定的檔案輸出到標準輸出
q -----快速地把檔案追加到靜態庫檔案中
r -----把檔案插入到靜態庫檔案中
t -----顯示靜態庫檔案中檔案的列表
x -----從靜態庫檔案中提取檔案
還有多個修飾符修改以上基本選項,詳細請man ar 以下列出三個:
a -----把新的目標檔案(*.o)新增到靜態庫檔案中現有檔案之後
b -----***************************************之前
v -----使用詳細模式
ar 命令的命令列格式如下:
ar [-][abcfilnopssuvv] [membername] [count] archive files...
引數archive定義庫的名稱, files是庫檔案中包含的目標檔案的清單, 用空格分隔每個檔案.
比如建立乙個靜態庫檔案的命令如下:
ar -r libapue.a error.o errorlog.o lockreg.o
這樣就了libapue.a靜態庫檔案, 可以用 t 選項顯示包含在庫中的檔案
建立庫檔案之後,可以建立這個靜態庫檔案的索引來幫助提高和庫連線的其他程式的編譯速度.使用ranlib程式建立庫的索引,索引存放在庫檔案內部.
ranlib libapue.a
用nm程式顯示存檔檔案的索引,它可以顯示目標檔案的符號
nm libapue.a | more
如果是顯示目標檔案的符號:
nm error.o | more
如何使用呢?如下所示:
gcc -o test test.c libapue.a
這樣就可以在test.c中呼叫在libapue.a中的函式了.
動態庫1.建立共享庫
gcc -shared -o libapue.so error.o errorlog.o
這樣就建立了共享庫!
2.編譯共享庫
假設共享庫位於當前目錄(即跟程式檔案相同的目錄中)
gcc -o test -l. -lapue test.c
這樣就編譯出了不包含函式**可執行檔案了,但是但你執行時會發現linux動態載入器打不到libapue.so檔案.
可以用ldd 命令檢視可執行檔案依賴什麼共享庫:
ldd test
如何才能讓動態載入器發現庫檔案呢?有兩種方法可以解決:
ld_library_path 環境變數
/etc/ld.so.conf檔案
1.環境變數
export ld_library_path="$ld_library_path:."
2.修改/etc/ld.so.conf檔案.位於/etc/ld.so.conf
一般應用程式的庫檔案不與系統庫檔案放在同乙個目錄下,一般把應用程式的共享庫檔案放在/usr/local/lib下,新建乙個屬於自己的目錄apue,然後把剛才libapue.so複製過去就行了
同時在/etc/ld.so.conf中新增一行:
/usr/local/lib/apue
以後在編譯程式時加上編譯選項:
-l/usr/local/lib/apue -lapue
這樣就可以使用這個libapue.so共享庫了!!
靜態庫 a和動態庫 so檔案的生成和使用
本文主要講解了靜態庫和動態庫的生成,以及.o檔案和.so檔案的使用。hello.件 ifndef hello h define hello h void hello const char name endif hello h hello.c include void hello const char...
靜態庫 a和動態庫 so生成及呼叫
gcc編譯器工具一般位於 usr bin或者 usr local bin目錄,但它會從其它位置執行各種編譯器支援的應用程式,這個位置可能是 usr lib gcc lib 目錄,gnu c c 編譯器的各個工具和gnu專用標頭檔案都儲存在這裡。標頭檔案,一般位於 usr include,包含標頭檔案...
Linux生成動態庫 so與生成靜態庫 a
動態庫共享庫 第一步 通過gcc fpic c 編譯生成.o檔案 gcc fpic c a.c 編譯生成.o檔案 fpic與位置無關 gcc fpic c b.c 生成a.o,b.o編譯檔案。第二步 通過上面已經生成的a.o,b.o檔案生成.so檔案 方法1 gcc shared wl o liba...