自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

詳解 QT 源碼之 QLibrary 跨平臺調(diào)用動態(tài)庫實現(xiàn)

移動開發(fā)
本文介紹將會介紹 QT 源碼之 QLibrary 跨平臺調(diào)用動態(tài)庫實現(xiàn),在內(nèi)容中,將會討論Qt是如何封裝這兩種不同的調(diào)用動態(tài)庫的方法。先看內(nèi)容。

詳解 QT 源碼之 QLibrary 跨平臺調(diào)用動態(tài)庫實現(xiàn)是本文要講解的內(nèi)容,在不同同臺上動態(tài)庫的使用,先來看內(nèi)容。

1、win下動態(tài)庫調(diào)用有關(guān)的函數(shù)包括:

(1)LoadLibrary,裝載動態(tài)庫。

(2)GetProcAddress,獲取要引入的函數(shù),將符號名或標(biāo)識號轉(zhuǎn)換為DLL內(nèi)部地址。

(3)FreeLibrary,釋放動態(tài)鏈接庫。

2、unix上與動態(tài)庫調(diào)用有關(guān)的函數(shù)包括:

(1)_打開動態(tài)鏈接庫:dlopen,函數(shù)原型void *dlopen (const char *filename, int flag);

dlopen用于打開指定名字(filename)的動態(tài)鏈接庫,并返回操作句柄。

(2)取函數(shù)執(zhí)行地址:dlsym,函數(shù)原型為: void *dlsym(void *handle, char *symbol);

dlsym根據(jù)動態(tài)鏈接庫操作句柄(handle)與符號(symbol),返回符號對應(yīng)的函數(shù)的執(zhí)行代碼地址。

(3)關(guān)閉動態(tài)鏈接庫:dlclose,函數(shù)原型為: int dlclose (void *handle);

dlclose用于關(guān)閉指定句柄的動態(tài)鏈接庫,只有當(dāng)此動態(tài)鏈接庫的使用計數(shù)為0時,才會真正被系統(tǒng)卸載。

(4)動態(tài)庫錯誤函數(shù):dlerror,函數(shù)原型為: const char *dlerror(void); 當(dāng)動態(tài)鏈接庫操作函數(shù)執(zhí)行失敗時,dlerror可以返回出錯信息,返回值為NULL時表示操作函數(shù)執(zhí)行成功。

我們來分析下Qt的源代碼,看看Qt是如何封裝這兩種不同的調(diào)用動態(tài)庫的方法。

下面是我用vc編寫的一個動態(tài)庫中的函數(shù)add:

  1. extern "C" __declspec(dllexport) int __stdcall add(int a,int b)  
  2. {  
  3.     return a+b;  

下面我就用QLibrary來調(diào)用一下:

  1. QLibrary lib("QtDllTest.dll");  
  2. if (lib.load())  
  3. {  
  4.     typedef int(*AddFunction)(int a,int b);  
  5.     AddFunction Add=(AddFunction)lib.resolve("add");  
  6.     if (!Add)  
  7.     {  
  8.         cout<<"failed"<<endl;  
  9.     }  
  10.     else  
  11.     {  
  12.        int m;  
  13.        m=Add(1,1); //來個計算1+1  
  14.        cout<<"result:"<<m<<endl;  
  15.     }  
  16.     lib.unload();  
  17. }  
  18. else  
  19. {  
  20.     cout<<"failed"<<endl;  

首先將目錄切換到QTDIR\src\corelib\plugin,這里面就是QLibrary實現(xiàn)的源代碼,打開qlibrary_p.h(熟悉了Qt的常用手法,就知道,這就是QLibrary內(nèi)部實現(xiàn)的代碼),可以看到

  1. bool load_sys();  
  2. bool unload_sys();  
  3. void *resolve_sys(const char *); 

三個函數(shù)。在qlibrary.cpp中可以找到調(diào)用這三個函數(shù)的地方

  1. bool QLibrary::load ()調(diào)用了load_sys;  
  2. bool QLibrary::unload ()調(diào)用了unload_sys;  
  3. void * QLibrary::resolve ( const char * symbol )調(diào)用了resolve_sys 

但是并沒有找到這三個函數(shù)的實現(xiàn),這是這么回事呢?

打開QTDIR\src\corelib\plugin\plugin.pri文件,

  1. win32 {  
  2.  SOURCES += plugin/qlibrary_win.cpp  
  3. }  
  4. unix {  
  5.  SOURCES += plugin/qlibrary_unix.cpp  

原來如此啊。

我們仔細看下qlibrary_win.cpp文件,load_sys函數(shù)調(diào)用了LoadLibrary,unload_sys調(diào)用了FreeLibrary,resolve_sys調(diào)用了GetProcAddress。

而在qlibrary_unix.cpp文件中,各種linux平臺又分好多種。但是基本上load_sys調(diào)用了dlopen,unload_sys調(diào)用了dlclose,resolve_sys調(diào)用了dlsym。

在HPUX中dlopen對應(yīng)shl_load,dlclose對應(yīng)shl_unload,dlsym對應(yīng)shl_findsym。

原來QLibrary就是這樣實現(xiàn)不同平臺動態(tài)庫的調(diào)用。

小結(jié):詳解 QT 源碼之 QLibrary 跨平臺調(diào)用動態(tài)庫實現(xiàn)的內(nèi)容介紹完了,希望本篇文章對你有所幫助!

責(zé)任編輯:zhaolei 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2011-06-24 09:01:20

Qt QLibrary dll

2012-07-06 15:10:39

跨平臺工具QtNokia

2011-06-23 14:05:32

Qt 事件機制

2011-06-21 14:01:07

QT 界面庫 Embedded

2011-07-08 20:54:12

iPhone WCF

2011-08-29 09:33:24

WindowsQt庫靜態(tài)

2011-06-23 13:38:27

QT 元對象 信號

2011-06-23 10:16:55

VS2010 QT 4.7.2 QT

2011-06-23 11:16:39

Qt Excel

2011-06-28 16:18:24

Qt QObject

2011-06-23 13:25:42

QT 源碼 窗口

2012-07-06 15:00:03

跨平臺工具MoSync

2012-07-06 15:08:14

跨平臺工具Netbiscuits

2023-02-10 14:54:20

編譯工具cmake

2011-06-20 13:54:41

Qt 動態(tài) 切換

2011-06-27 16:59:19

Qt 動態(tài) 插件

2011-06-23 15:32:05

Qt Windows消息

2011-04-01 10:40:53

WCFiPhone調(diào)用

2011-06-23 15:10:39

Qt 窗體

2012-06-14 09:42:20

跨平臺工具AppceleratoTitanium
點贊
收藏

51CTO技術(shù)棧公眾號