?? 深入分析windows和linux動(dòng)態(tài)庫應(yīng)用異同 .txt
字號(hào):
除了采用這種方式編寫和調(diào)用動(dòng)態(tài)庫之外,Linux操作系統(tǒng)也提供了一種更為方便的動(dòng)態(tài)庫調(diào)用方式,也方便了其它程序調(diào)用,這種方式與Windows系統(tǒng)的隱式鏈接類似。其動(dòng)態(tài)庫命名方式為“l(fā)ib*.so.*”。在這個(gè)命名方式中,第一個(gè)*表示動(dòng)態(tài)鏈接庫的庫名,第二個(gè)*通常表示該動(dòng)態(tài)庫的版本號(hào),也可以沒有版本號(hào)。
在這種調(diào)用方式中,需要維護(hù)動(dòng)態(tài)鏈接庫的配置文件/etc/ld.so.conf來讓動(dòng)態(tài)鏈接庫為系統(tǒng)所使用,通常將動(dòng)態(tài)鏈接庫所在目錄名追加到動(dòng)態(tài)鏈接庫配置文件中。如具有X window窗口系統(tǒng)發(fā)行版該文件中都具有/usr/X11R6/lib,它指向X window窗口系統(tǒng)的動(dòng)態(tài)鏈接庫所在目錄。
為了使動(dòng)態(tài)鏈接庫能為系統(tǒng)所共享,還需運(yùn)行動(dòng)態(tài)鏈接庫的管理命令./sbin/ldconfig。在編譯所引用的動(dòng)態(tài)庫時(shí),可以在gcc采用 –l或-L選項(xiàng)或直接引用所需的動(dòng)態(tài)鏈接庫方式進(jìn)行編譯。在Linux里面,可以采用ldd命令來檢查程序依賴共享庫。
3、兩種系統(tǒng)動(dòng)態(tài)庫比較分析
Windows和Linux采用動(dòng)態(tài)鏈接庫技術(shù)目的是基本一致的,但由于操作系統(tǒng)的不同,他們?cè)谠S多方面還是不盡相同,下面從以下幾個(gè)方面進(jìn)行闡述。
(1)動(dòng)態(tài)庫程序編寫,在Windows系統(tǒng)下的執(zhí)行文件格式是PE格式,動(dòng)態(tài)庫需要一個(gè)DllMain函數(shù)作為初始化的人口,通常在導(dǎo)出函數(shù)的聲明時(shí)需要有_declspec(dllexport)關(guān)鍵字。Linux下的gcc編譯的執(zhí)行文件默認(rèn)是ELF格式,不需要初始化入口,亦不需要到函數(shù)做特別聲明,編寫比較方便。
(2)動(dòng)態(tài)庫編譯,在windows系統(tǒng)下面,有方便的調(diào)試編譯環(huán)境,通常不用自己去編寫makefile文件,但在linux下面,需要自己動(dòng)手去編寫makefile文件,因此,必須掌握一定的makefile編寫技巧,另外,通常Linux編譯規(guī)則相對(duì)嚴(yán)格。
(3)動(dòng)態(tài)庫調(diào)用方面,Windows和Linux對(duì)其下編制的動(dòng)態(tài)庫都可以采用顯式調(diào)用或隱式調(diào)用,但具體的調(diào)用方式也不盡相同。
(4)動(dòng)態(tài)庫輸出函數(shù)查看,在Windows中,有許多工具和軟件可以進(jìn)行查看DLL中所輸出的函數(shù),例如命令行方式的dumpbin以及VC++工具中的DEPENDS程序。在Linux系統(tǒng)中通常采用nm來查看輸出函數(shù),也可以使用ldd查看程序隱式鏈接的共享對(duì)象文件。
(5)對(duì)操作系統(tǒng)的依賴,這兩種動(dòng)態(tài)庫運(yùn)行依賴于各自的操作系統(tǒng),不能跨平臺(tái)使用。因此,對(duì)于實(shí)現(xiàn)相同功能的動(dòng)態(tài)庫,必須為兩種不同的操作系統(tǒng)提供不同的動(dòng)態(tài)庫版本。
4、動(dòng)態(tài)庫移植方法
如果要編制在兩個(gè)系統(tǒng)中都能使用的動(dòng)態(tài)鏈接庫,通常會(huì)先選擇在Windows的VC++提供的調(diào)試環(huán)境中完成初始的開發(fā),畢竟VC++提供的圖形化編輯和調(diào)試界面比vi和gcc方便許多。完成測(cè)試之后,再進(jìn)行動(dòng)態(tài)庫的程序移植。
通常gcc默認(rèn)的編譯規(guī)則比VC++默認(rèn)的編譯規(guī)則嚴(yán)格,即使在VC++下面沒有任何警告錯(cuò)誤的程序在gcc調(diào)試中也會(huì)出現(xiàn)許多警告錯(cuò)誤,可以在gcc中采用-w選項(xiàng)關(guān)閉警告錯(cuò)誤。
下面給出程序移植需要遵循的規(guī)則以及經(jīng)驗(yàn)。
(1)盡量不要改變?cè)袆?dòng)態(tài)庫頭文件的順序。通常在C/C++語言中,頭文件的順序有相當(dāng)?shù)年P(guān)系。另外雖然C/C++語言區(qū)分大小寫,但在包含頭文件時(shí),Linux必須與頭文件的大小寫相同,因?yàn)閑xt2文件系統(tǒng)對(duì)文件名是大小寫敏感,否則不能正確編譯,而在Windows下面,頭文件大小寫可以正確編譯。
(2)不同系統(tǒng)獨(dú)有的頭文件。在Windows系統(tǒng)中,通常會(huì)包括windows.h頭文件,如果調(diào)用底層的通信函數(shù),則會(huì)包含winsock..h頭文件。因此在移植到Linux系統(tǒng)時(shí),要注釋掉這些Windows系統(tǒng)獨(dú)有的頭文件以及一些windows系統(tǒng)的常量定義說明,增加Linux都底層通信的支持的頭文件等。
(3)數(shù)據(jù)類型。VC++具有許多獨(dú)有的數(shù)據(jù)類型,如__int16,__int32,TRUE,SOCKET等,gcc編譯器不支持它們。通常做法是需要將windows.h和basetypes.h中對(duì)這些數(shù)據(jù)進(jìn)行定義的語句復(fù)制到一個(gè)頭文件中,再在Linux中包含這個(gè)頭文件。例如將套接字的類型為SOCKET改為int。
(4)關(guān)鍵字。VC++中具有許多標(biāo)準(zhǔn)C中所沒有采用的關(guān)鍵字,如BOOL,BYTE,DWORD,__asm等,通常在為了移植方便,盡量不使用它們,如果實(shí)在無法避免可以采用#ifdef 和#endif為L(zhǎng)INUX和WINDOWS編寫兩個(gè)版本。
(5)函數(shù)原型的修改。通常如果采用標(biāo)準(zhǔn)的C/C++語言編寫的動(dòng)態(tài)庫,基本上不用再重新編寫函數(shù),但對(duì)于系統(tǒng)調(diào)用函數(shù),由于兩種系統(tǒng)的區(qū)別,需要改變函數(shù)的調(diào)用方式等,如在Linux編制的網(wǎng)絡(luò)通信動(dòng)態(tài)庫中,用close()函數(shù)代替windows操作系統(tǒng)下的closesocket()函數(shù)來關(guān)閉套接字。另外在Linux下沒有文件句柄,要打開文件可用open和fopen函數(shù),具體這兩個(gè)函數(shù)的用法可參考文獻(xiàn)[2]。
(6)makefile的編寫。在windows下面通常由VC++編譯器來負(fù)責(zé)調(diào)試,但gcc需要自己動(dòng)手編寫makefile文件,也可以參照VC++生成的makefile文件。對(duì)于動(dòng)態(tài)庫移植,編譯動(dòng)態(tài)庫時(shí)需要加入-shared選項(xiàng)。對(duì)于采用數(shù)學(xué)函數(shù),如冪級(jí)數(shù)的程序,在調(diào)用動(dòng)態(tài)庫是,需要加入-lm。
(7)其它一些需要注意的地方
①程序設(shè)計(jì)結(jié)構(gòu)分析,對(duì)于移植它人編寫的動(dòng)態(tài)庫程序,程序結(jié)構(gòu)分析是必不可少的步驟,通常在動(dòng)態(tài)庫程序中,不會(huì)包含界面等操作,所以相對(duì)容易一些。
②在Linux中,對(duì)文件或目錄的權(quán)限分為擁有者、群組、其它。所以在存取文件時(shí),要注意對(duì)文件是讀還是寫操作,如果是對(duì)文件進(jìn)行寫操作,要注意修改文件或目錄的權(quán)限,否則無法對(duì)文件進(jìn)行寫。
③指針的使用,定義一個(gè)指針只給它分配四個(gè)字節(jié)的內(nèi)存,如果要對(duì)指針?biāo)赶虻淖兞抠x值,必須用malloc函數(shù)為它分配內(nèi)存或不把它定義為指針而定義為變量即可,這點(diǎn)在linux下面比windows編譯嚴(yán)格。同樣結(jié)構(gòu)不能在函數(shù)中傳值,如果要在函數(shù)中進(jìn)行結(jié)構(gòu)傳值,必須把函數(shù)中的結(jié)構(gòu)定義為結(jié)構(gòu)指針。
④路徑標(biāo)識(shí)符,在Linux下是“/”,在Windows下是“\”,注意windows和Linux的對(duì)動(dòng)態(tài)庫搜索路徑的不同。
⑤編程和調(diào)試技巧方面。對(duì)不同的調(diào)試環(huán)境有不同的調(diào)試技巧,在這里不多敘述。
5、結(jié)束語
本文系統(tǒng)分析了windows和Linux動(dòng)態(tài)庫實(shí)現(xiàn)和使用方式,從程序編寫、編譯、調(diào)用以及對(duì)操作系統(tǒng)依賴等方面綜合分析比較了這兩種調(diào)用方式的不同之處,根據(jù)實(shí)際程序移植經(jīng)驗(yàn),給出了將VC++編制的Windows動(dòng)態(tài)庫移植到Linux下的方法以及需要注意的問題,同時(shí)并給出了程序示例片斷,實(shí)際在程序移植過程中,由于系統(tǒng)的設(shè)計(jì)等方面,可能移植起來需要注意的方面遠(yuǎn)比上面復(fù)雜,本文通過總結(jié)歸納進(jìn)而為不同操作系統(tǒng)程序移植提供了有意的經(jīng)驗(yàn)和技巧。
責(zé)任編輯: otto
發(fā)表評(píng)論 查看評(píng)論 加入收藏 Email給朋友 打印本文
如果你想對(duì)該文章評(píng)分, 請(qǐng)先登陸, 如果你仍未注冊(cè),請(qǐng)點(diǎn)擊注冊(cè)鏈接注冊(cè)成為本站會(huì)員. 平均得分 10.00, 共 1 人評(píng)分
1 2 3 4 5 6 7 8 9 10
Copyright ? 2002 -2003 Linuxeden.com-- Linuxeden 新聞 文檔 資料 教程 Linux伊甸園
All rights reserved.
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -