linux靜態鏈接
❶ 在linux下,如何強制讓GCC靜態鏈接
在編譯命令行中,將使用的靜態庫文件放在源文件後面就可以了。比如:gcc-L/usr/lib myprop.c libtest.a libX11.a libpthread.a -o myprop 其中-L/usr/lib指定庫文件的查找路徑,編譯器默認在當前目錄下先查找指定的庫文件。
❷ linux下的動態鏈接庫和靜態鏈接庫到底是個什麼鬼
Linux中動態鏈接庫是.so為後綴的文件,靜態鏈接庫是.a為後綴的文件,.a和.so文件都叫做函數庫文件。庫是一組預先編譯好的函數的集合,庫文件的名字以lib開頭,隨後的部分指明這是什麼庫(例如libc代表c語言庫,libm.a的m代表數學庫)。
.a靜態函數庫:當同時運行多個程序並且都使用到同一個函數庫的函數時,內存中就會有同一函數的多份副本,會消耗大量寶貴的內存。
.so共享函數庫:可以克服.a函數庫的不足。當一個程序使用共享函數庫時,程序本身不再包含函數代碼,而只是引用共享代碼,當實際調用時,共享庫才被載入到內存中。
.a文件類似於Windows下的.lib文件,.so文件類似於Windows下面的.dll文件,這樣就好理解了。
❸ linux 動態鏈接和靜態鏈接的區別
兩者區別:a,靜態庫的使用需要:1包含一個對應的頭文件告知編譯器lib文件裡面的具體內容2設置lib文件允許編譯器去查找已經編譯好的二進制代碼b,動態庫的使用:程序運行時需要載入動態庫,對動態庫有依賴性,需要手動加入動態庫c,依賴性:靜態鏈接表示靜態性,在編譯鏈接之後,lib庫中需要的資源已經在可執行程序中了,也就是靜態存在,沒有依賴性了動態,就是實時性,在運行的時候載入需要的資源,那麼必須在運行的時候提供需要的動態庫,有依賴性,運行時候沒有找到庫就不能運行了d,區別:簡單講,靜態庫就是直接將需要的代碼連接進可執行程序;動態庫就是在需要調用其中的函數時,根據函數映射表找到該函數然後調入堆棧執行。做成靜態庫可執行文件本身比較大,但不必附帶動態庫做成動態庫可執行文件本身比較小,但需要附帶動態庫鏈接靜態庫,編譯的可執行文件比較大,當然可以用strip命令精簡一下(如:striplibtest.a),但還是要比鏈接動態庫的可執行文件大。程序運行時間速度稍微快一點。靜態庫是程序運行的時候已經調入內存,不管有沒有調用,都會在內存里頭。靜態庫在程序編譯時會被連接到目標代碼中,程序運行時將不再需要該靜態庫。其在編譯程序時若鏈接,程序運行時會在系統指定的路徑下搜索,然後導入內存,程序一般執行時間稍微長一點,但編譯的可執行文件比較小;動態庫是程序運行的時候需要調用的時候才裝入內存,不需要的時候是不會裝入內存的。動態庫在程序編譯時並不會被連接到目標代碼中,而是在程序運行是才被載入,因此在程序運行時還需要動態庫存在。動態鏈接庫的特點與優勢首先讓我們來看一下,把庫函數推遲到程序運行時期載入的好處:1.可以實現進程之間的資源共享。什麼概念呢?就是說,某個程序的在運行中要調用某個動態鏈接庫函數的時候,操作系統首先會查看所有正在運行的程序,看在內存里是否已有此庫函數的拷貝了。如果有,則讓其共享那一個拷貝;只有沒有才鏈接載入。這樣的模式雖然會帶來一些「動態鏈接」額外的開銷,卻大大的節省了系統的內存資源。C的標准庫就是動態鏈接庫,也就是說系統中所有運行的程序共享著同一個C標准庫的代碼段。2.將一些程序升級變得簡單。用戶只需要升級動態鏈接庫,而無需重新編譯鏈接其他原有的代碼就可以完成整個程序的升級。Windows就是一個很好的例子。3.甚至可以真正坐到鏈接載入完全由程序員在程序代碼中控制。程序員在編寫程序的時候,可以明確的指明什麼時候或者什麼情況下,鏈接載入哪個動態鏈接庫函數。你可以有一個相當大的軟體,但每次運行的時候,由於不同的操作需求,只有一小部分程序被載入內存。所有的函數本著「有需求才調入」的原則,於是大大節省了系統資源。比如現在的軟體通常都能打開若干種不同類型的文件,這些讀寫操作通常都用動態鏈接庫來實現。在一次運行當中,一般只有一種類型的文件將會被打開。所以直到程序知道文件的類型以後再載入相應的讀寫函數,而不是一開始就將所有的讀寫函數都載入,然後才發覺在整個程序中根本沒有用到它們。靜態庫:在編譯的時候載入生成目標文件,在運行時不用載入庫,在運行時對庫沒有依賴性。動態庫:在目標文件運行時載入,手動載入,且對庫有依賴性。具體在開發中用到哪種庫,我覺得還是根據實際的內存大小,ROM大小,運行的速度等綜合考慮。
❹ Linux動態鏈接和靜態鏈接簡析
linux動態鏈接和靜態鏈接簡析1.生成靜態鏈接庫gcc
-c
h.c
-o
h.oar
cqs
libh.a
h.o//ar是生成庫的命令,cqs是參數,libh.a是生成的靜態鏈接庫須以lib開頭,h是庫名,a表示是靜態鏈接庫,h.o是剛才生成目標文件2.生成動態鏈接庫
www.shiwu.com
gcc
-c
h.c
-o
h.o生成動態鏈接庫用gcc來完成gcc
-shared
-WI
-o
libh.so
h.o//-shared
-WI是參數,libh.so是生成的靜態鏈接庫須以lib開頭,h是庫名,so表示是動態鏈接庫,h.o是剛才生成目標文件3.將生成的libh.a,libh.so拷貝到/usr/lib或/lib下4.編譯帶靜態鏈接庫的程序gcc
-c
test.c
-o
test.ogcc
test.o
-o
test
-WI
-Bstatic
-lh//-WI
-Bstatic表示鏈接靜態庫,-lh中-l表示鏈接,h是庫名即/usr/lib下的libh.a5.編譯帶動態鏈接庫的程序gcc
-c
test.c
-o
test.ogcc
test.o
-o
test
-WI
-Bdynamic
-lh//-WI
-Bdynamic表示鏈接動態庫,-lh中-l表示鏈接,h是庫名即/usr/lib下的libh.so6.運行./test得到結果
www.shiwu.com
7.其他知識有些庫形如libh.so.1.0,1.0表示版本號.若要使用該庫,通常要建立一個軟連接,用ln
-s
libh.so.1.0
libh.so.系統不知道1.0為何意思。編譯連接時同時要用動態和靜態鏈接庫,則用如下命令gcc
test.o
-o
test
-WI
-Bstatic
-lh1
-WI
-Bdynamic
-lh28.動態庫和靜態庫的位置問題把動態庫或者靜態庫放在/usr/lib或者/lib下,在鏈接的時候系統會自動到這兩個目錄下尋找。如果沒有放在這兩個目錄下,則修改/etc/ld.so.conf文件,把目錄寫入該文件,然後ldconfig,就OK了。如果沒有放在usr/lib或者/lib目錄下,也不修改/etc/ld.so.conf文件,也可以在編譯的時候加上
-L/路徑
也可以。但是在執行的時候還是會提示找不到庫的所在。
作者
llg521208
❺ linux把幾個靜態庫鏈接進目標文件中
靜態庫不能被打包到.o 文件
在C編譯中, 是.c編譯成.o,然後若干個.o打包成.a
.a要比.o高一級的。 所以不能產生新的.o
你可以把.a文件解開 成為.o集合
加上你的.o文件, 共同打包成一個新的.a文件
這樣是可行的。
❻ linux 怎麼指定靜態鏈接靜態庫
創建靜態庫: ar -rcs test.a *.o 查看靜態庫: ar -tv test.a 解壓靜態庫: ar -x test.a 查看程序依賴的動態庫: readelf -a xxx|grep library 如:可以看到,下面的交叉程序hello執行依賴於如下兩個動態庫。 rebi@ubuntu:~/test$ arm-none-li...
❼ linux怎樣實現c語言動態庫與靜態庫的鏈接
Linux系統中靜態庫是.a文件,編譯鏈接.a文件只需要加上.a文件的完整的文件路徑就可以了,比如:
gcc
-o
hello
hello.c
/usr/lib/libm.a
Linux系統的動態庫是系統中的.so文件,編譯鏈接動態庫需要用-L參數指定動態庫的搜索路徑,還要用-l(這個是小寫的L)指定動態庫的名字,比如:
gcc
-o
hello
hello.c
-L/usr/openssl/lib
-lcrypto
❽ Linux下載入靜態鏈接庫
dll文件,貌似是windows下的動態鏈接庫,屬於pe文件。linux下怎麼可能載入那種東西呢。
❾ 如何以靜態鏈接方式交叉編譯linux上的軟體n
在編譯命令行中,將使用的靜態庫文件放在源文件後面就可以了。比如:
gcc -L/usr/lib myprop.c libtest.a libX11.a libpthread.a -o myprop
其中-L/usr/lib指定庫文件的查找路徑,編譯器默認在當前目錄下先查找指定的庫文件。