動態庫編譯-ag真人国际官网
⑴ makefile 怎麼寫動態庫編譯
target = client # 這里修改你的庫名
target_lib = $(target:%=lib%.a)
crosscompiler =#arm-hisiv200-linux-
cc = $(crosscompiler)gcc
ar = $(crosscompiler)ar
cflags = #-ddebug
incs = -i./
libs = -lpthread
sources = main.c #這里添加你的c文件
objects = $(sources:.c=.o)
all: $(target_lib) #$(target) #修改這里可以更改編譯目標
$(target) : $(objects)
$(cc) -o2 -o $@ $(incs) $(cflags) $^ $(libs)
$(target_lib) : $(objects)
$(ar) -rv -o $@ $^
%.o:%.c
$(cc) -o2 -c -o $@ $(incs) $(cflags) $^
clean:
@rm -vrf $(target) $(target_lib) $(objects)
#注意網路把tab自動刪除了要補上
⑵ php動態庫怎麼編譯
# 聲稱動代連接庫,假設名稱為libtest.so
gcc x.c y.c z.c -fpic -shared -o libtest.so
# 將main.c和動態連接庫進行連接生成可執行文件
gcc main.c -l. -ltest -o main
# 輸出ld_library_path環境變數,一邊動態庫裝載器能夠找到需要的動態庫
export ld_library_path=$ld_library_path:.
# 測試是否動態連接,如果列出libtest.so,那麼應該是連接正常了
ldd main
# 執行就不用說了吧
--------------------------------------------------
建議創建一個makefile來作這些事情。
⑶ linux下,有幾個.so。如何將這幾個動態庫編譯成一個動態庫
g -l*** -l*** -l 庫目錄. 一次g 是可以同時連接多個動態庫的.不用把多個動態庫編成一個.
⑷ 如何編譯動態庫,該動態庫需要鏈接另外一個動態庫
看你的makefile, 猜測是沒有指定動態庫頭文件的路徑. -i編譯參數來指定
⑸ 動態庫的編譯
生成動態連接庫,假設名稱為libtest.so
gcc x.cy.cz.c-fpic-shared-olibtest.so
將main.c和動態連接庫進行連接生成可執行文件
gcc main.c-l.-ltest-omain
輸出ld_library_path環境變數,以便動態庫裝載器能夠找到需要的動態庫
export ld_library_path=$ld_library_path:.
測試是否動態連接,如果列出libtest.so,那麼應該是連接正常了
ldd main
⑹ 動態庫鏈接編譯
這里的動態的意思應該是模塊代碼是動態載入的
而不是隨著應用程序一起編譯
只要動態庫里的函數介面不變
應用程序就無需重新編譯
只需將動態庫重新編譯後替換掉舊的動態庫即可
如果動態庫的函數介面有變動
那麼應用程序就要重新編譯發布
這也是我的個人理解~~~
⑺ 缺少動態庫的情況下,能通過編譯嗎
>> 如果你是鏈接動態庫,在gcc後跟了一個-l參數,其後就是你所需庫的名稱,
>> 那麼你不僅需要那個你所需的庫文件,還需要你所需庫的頭文件才行,編譯時需要頭文件支持,
>> 鏈接時需要庫文件,不管你是動態還是靜態編譯都是如此!!!!
頭文件不是必須的。只要沒有出現未聲明的函數/變數的調用就可以。
>> 還需說明的一點是:只有用參數-o時才會有那個-satic的選項,
>> 也就是說只有在鏈接程序時才會有動態鏈接和靜態鏈接之分!!!!!!
沒有 -o 也可以 -static。-o 不代表鏈接
>> 動態鏈接庫是為了減少可執行文件的大小,就是在一個系統中只提供一個庫,
>> 可供多個動態鏈接的程序共同使用
同時也避免庫代碼被重復載入進入內存,減少系統內存佔用
⑻ linux 靜態庫和動態庫編譯的區別
linux庫有動態與靜態兩種,動態通常用.so為後綴,靜態用.a為後綴。例如:libhello.so libhello.a
為了在同一系統中使用不同版本的庫,可以在庫文件名後加上版本號為後綴,例如: libhello.so.1.0,由於程序連接默認以.so為文件後綴名。所以為了使用這些庫,通常使用建立符號連接的方式。
ln -s libhello.so.1.0 libhello.so.1
ln -s libhello.so.1 libhello.so
動態庫和靜態庫的區別:
當要使用靜態的程序庫時,連接器會找出程序所需的函數,然後將它們拷貝到執行文件,由於這種拷貝是完整的,所以一旦連接成功,靜態程序庫也就不再需要了。然而,對動態庫而言,就不是這樣。動態庫會在執行程序內留下一個標記『指明當程序執行時,首先必須載入這個庫。由於動態庫節省空間,linux下進行連接的預設操作是首先連接動態庫,也就是說,如果同時存在靜態和動態庫,不特別指定的話,將與動態庫相連接。
兩種庫的編譯產生方法:
第一步要把源代碼編繹成目標代碼。以下面的代碼hello.c為例,生成hello庫:
/* hello.c */
#include
void sayhello()
{
printf("hello,world\n");
}
用gcc編繹該文件,在編繹時可以使用任何全法的編繹參數,例如-g加入調試代碼等:
gcc -c hello.c -o hello.o
1.連接成靜態庫
連接成靜態庫使用ar命令,其實ar是archive的意思
$ar cqs libhello.a hello.o
2.連接成動態庫
生成動態庫用gcc來完成,由於可能存在多個版本,因此通常指定版本號:
$gcc -shared -wl,-soname,libhello.so.1 -o libhello.so.1.0 hello.o
另外再建立兩個符號連接:
$ln -s libhello.so.1.0 libhello.so.1
$ln -s libhello.so.1 libhello.so
這樣一個libhello的動態連接庫就生成了。最重要的是傳gcc -shared 參數使其生成是動態庫而不是普通執行程序。
-wl 表示後面的參數也就是-soname,libhello.so.1直接傳給連接器ld進行處理。實際上,每一個庫都有一個soname,當連接器發現它正在查找的程序庫中有這樣一個名稱,連接器便會將soname嵌入連結中的二進制文件內,而不是它正在運行的實際文件名,在程序執行期間,程序會查找擁有 soname名字的文件,%b
⑼ linux 編譯怎麼連接動態庫
linux的動態庫文件是以lib字樣開頭的.so文件,編譯鏈接動態庫有兩個要點:一個是需要用-l選項指定動態庫的搜索路徑,這個搜索路徑是需要連接的so文件的大致路徑,比如/usr/openssl/lib;另外還需要用-l(這個是小寫的l)選項指定動態庫的名字,比如下面這條編譯命令:
gcc -o hello hello.c -l/usr/openssl/lib -lcrypto
⑽ linux動態庫編譯
linux動態庫的編譯與使用 轉載
http://hi..com/linuxlife/blog/item/0d3e302ae2384d3a5343c1b1.html
linux下的動態庫以.so為後綴,我也是初次在linux下使用動態庫,寫一點入門步驟,以便以後能方便使用。
第一步:編寫linux程序庫
文件1.動態庫介面文件
//動態庫介面文件getmaxlen.h
#ifndef _getmaxlen_h_
#define _getmaxlen_h_
int getmaxlen(int *sel,int n);
#endif
文件2.動態庫程序實現文件
//動態庫程序實現文件getmaxlen.c
#include "getmaxlen.h"
int getmaxlen(int *sel,int n)
{
int n1=1,n2=1;
for(int i=1;i
if(sel[i]>sel[i-1])
{
n2 ;
if(n2 > n1)
{
n1 = n2;
}
}
else
{
n2 = 1;
}
}
return n1;
}
第二步:編譯生成動態庫
gcc getmaxlen.c –fpic –shared –o libtest.so
由以上命令生成動態庫libtest.so,為了不需要動態載入動態庫,在命令時需以lib開頭以.so為後綴。
–fpic:表示編譯為位置獨立的代碼,不用此選項的話編譯後的代碼是位置相關的所以動態載入時是通過代碼拷貝的方式來滿足不同進程的需要,而不能達到真正代碼段共享的目的。
–shared:指明編譯成動態庫。
第三步:使用動態庫
1. 編譯時使用動態庫
文件1.動態庫使用文件test.c
//使用動態庫libtest.so,該文件名為test.c
#include "getmaxlen.h"
int main()
{
int sel[] = {2,3,6,5,3,2,1,2,3,4,5,6,7,6,5};
int m;
m = getmaxlen(sel,15);
printf("%d",m);
return 0;
}
編譯命令:
gcc test.c –l . –l test –o test
–l:指明動態庫所在的目錄
-l:指明動態庫的名稱,該名稱是處在頭lib和後綴.so中的名稱,如上動態庫libtest.so的l參數為-l test。
測試:
ldd test
ldd 測試可執行文件所使用的動態庫
2. 動態載入方式使用動態庫
文件內容:
//動態庫的動態載入使用
int main()
{
void *handle = null;
int (*getmaxlen)(int *sel,int n);
int sel[] = {1,2,5,4,5,8,6,5,9,5,4,5,4,1};
handle = dlopen("./libtest.so",rtld_lazy);
if(handle == null)
{
printf("dll loading error.\n");
return 0;
}
getmaxlen = (int(*)(int *,int))dlsym(handle,"getmaxlen");
if(dlerror()!=null)
{
printf("fun load error.\n");
return 0;
}
printf("%d\n",getmaxlen(sel,15));
}
編譯命令:
gcc –ldl test1.c –o test
gcc -o test test.c ./libmytools.so