Linux下編譯靜態庫 a 和動態庫 so

2021-06-18 16:58:58 字數 2037 閱讀 9061

靜態庫

在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共享庫了!!

linux 下編譯生成靜態庫和動態庫

我們此處為了說明靜態庫和動態庫的編譯,會使用示例 建立 test.h,hello.cpp 和 world.cpp,在兩個原始檔中分別實現兩個函式 此處都是示例 檔案命名不規範,理解意思即可 test.h 靜態庫標頭檔案 ifndef test define test void hello void ...

linux下的靜態庫和動態庫的編譯

每個程式實質上都會鏈結到乙個或者多個的庫。比如使用c函式的程式會鏈結到c執行時庫,gui程式會鏈結到視窗庫等等。無論哪種情況,你都會要決定是鏈結到靜態庫 static libary 還是動態庫 dynamic libary 鏈結到靜態庫會使你的程式臃腫,並且難以公升級,但是可能會比較容易部署。而鏈結...

linux下的靜態庫和動態庫的編譯

每個程式實質上都會鏈結到乙個或者多個的庫。比如使用c函式的程式會鏈結到c執行時庫,gui程式會鏈結到視窗庫等等。無論哪種情況,你都會要決定是鏈結到靜態庫 static libary 還是動態庫 dynamic libary 鏈結到靜態庫會使你的程式臃腫,並且難以公升級,但是可能會比較容易部署。而鏈結...