日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
淺析C++動(dòng)態(tài)加載DLL在Windows Mobile下實(shí)現(xiàn)

我們將在這里為大家講解Windows Mobile下Native C++動(dòng)態(tài)加載DLL的實(shí)現(xiàn),一般來說靜態(tài)加載是很簡(jiǎn)單的事情,我們?cè)诒疚闹幸矊?huì)提到。主要還是講解C++動(dòng)態(tài)加載DLL。

簡(jiǎn)介

本文以Windows Mobile Sensors API庫為例子講述在Windows Mobile下使用Native C++動(dòng)態(tài)加載DLL的方法。

靜態(tài)加載DLL的方法

使用Native C++的開發(fā),一般使用靜態(tài)加載的方法加載DLL,所謂靜態(tài)加載就是在程序編譯時(shí)(Compile Time)直接調(diào)用DLL的頭文件定義的函數(shù),鏈接時(shí)(Link Time)鏈接*.lib文件指向DLL的接口,在程序開始運(yùn)行時(shí)(Run Time Start up)加載DLL。

下面講述使用靜態(tài)加載DLL的方法,在程序中需要指定加載的*.lib文件,用于鏈接(Link)。

#pragma comment(lib, "SamsungMobileSDK_1.lib")

使用靜態(tài)加載的DLL可以直接調(diào)用頭文件定義的函數(shù),例如:

 
 
 
  1. SmiAccelerometerCapabilities cap;
  2. if( SmiAccelerometerGetCapabilities(&cap) != SMI_SUCCESS){    throw;}
  3. SmiAccelerometerHandler h = &GetVectorHandler;if(SmiAccelerometerRegisterHandler(1000, h) != SMI_SUCCESS)
  4. {    throw;} 

SmiAccelerometerGetCapabilities()和SmiAccelerometerRegisterHandler()是定義在頭文件smiAccelerometer.h中的,可以直接調(diào)用,定義如下:

使用靜態(tài)加載的方法使用方面還是很方便的,可是在動(dòng)態(tài)加載的時(shí)候就不能直接調(diào)用頭文件的函數(shù)了,增加了復(fù)雜度,下面會(huì)講到。

 
 
 
  1. /**  
  2. *  Start receiving accelerometer data periodically.   
  3. *   
  4. *  The period interval must be a multiple of the callbackPeriod specified   
  5. *  in SmiAccelerometerCapabilities. If it is less than the callbackPeriod, it will be   
  6. *  set to the callbackPeriod. If it is not a multiple of the callbackPeriod, it will be   
  7. *  truncated to fit the value. ( (period / callbackPeriod)   
  8. * callbackPeriod )   
  9. *     
  10. *  Only one handler per process is allowed. Successive calls per process will replace the previous handler   
  11. *  function and period.   
  12. *  
  13. *  @param    period    [in]    callback interval.      
  14. *  @param    handler   [in]    callback function for every period interval.     
  15. *   
  16. *  @return                      
  17. *                              SMI_SUCCESS on success   
  18. *  \n                          SMI_ERROR_INVALID_PARAMETER if the handler input parameter is NULL   
  19. *  \n                          SMI_ERROR_DEVICE_NOT_FOUND if the device is not present or supported   
  20. *  \n                          SMI_ERROR_CANNOT_ACTIVATE_SERVER if the sensor server cannot be started   
  21. */ SMI_API SMI_RESULT SmiAccelerometerRegisterHandler(UINT period, SmiAccelerometerHandler handler); 

C++動(dòng)態(tài)加載DLL的方法

靜態(tài)加載DLL是比較簡(jiǎn)單的開發(fā)方法,可是有個(gè)缺點(diǎn)是程序開始運(yùn)行的時(shí)候就需要加載DLL,如果該DLL不存在,程序就不能啟動(dòng)了。由于Windows Mobile Sensors API庫需要自適應(yīng)具體的設(shè)備,也就是說Windows Mobile Sensors API庫不能依賴于具體設(shè)備的Sensor庫,所以不能使用靜態(tài)加載的方法來引用DLL。下面講述動(dòng)態(tài)加載DLL的方法。

定義指向函數(shù)的指針

動(dòng)態(tài)加載DLL,需要根據(jù)頭文件來定義指向函數(shù)的指針,如下:

 
 
 
  1. typedef UINT (WINAPI * PFN_SmiAccelerometerGetVector)(SmiAccelerometerVector*);  
  2. typedef UINT (WINAPI * PFN_SmiAccelerometerGetCapabilities)(SmiAccelerometerCapabilities*);  
  3. typedef UINT (WINAPI * PFN_SmiAccelerometerRegisterHandler)(UINT, SmiAccelerometerHandler);typedef UINT (WINAPI * PFN_SmiAccelerometerUnregisterHandler)();  
  4. PFN_SmiAccelerometerGetVector pfnSmiAccelerometerGetVector;PFN_SmiAccelerometerGetCapabilities   
  5. pfnSmiAccelerometerGetCapabilities;PFN_SmiAccelerometerRegisterHandler   
  6. pfnSmiAccelerometerRegisterHandler;PFN_SmiAccelerometerUnregisterHandler pfnSmiAccelerometerUnregisterHandler; 

這些指向函數(shù)的指針可以對(duì)應(yīng)下面的在smiAccelerometer.h頭文件的函數(shù)進(jìn)行定義:

 
 
 
  1. SMI_API SMI_RESULT SmiAccelerometerGetVector(SmiAccelerometerVector *accel);  
  2. SMI_API SMI_RESULT SmiAccelerometerGetCapabilities(SmiAccelerometerCapabilities *capabilities);  
  3. SMI_API SMI_RESULT SmiAccelerometerRegisterHandler(UINT period, SmiAccelerometerHandler handler);  
  4. SMI_API SMI_RESULT SmiAccelerometerUnregisterHandler(); 

定義是一一對(duì)應(yīng)的。參數(shù)入口和返回值都必須完全一致。

初始化指向函數(shù)的指針

初始化指向函數(shù)的指針的過程也就是動(dòng)態(tài)加載DLL的過程,代碼如下:

 
 
 
  1. #define SAMSUNG_SENSOR_DLL  
  2. L"SamsungMobilesdk_1.dll"HMODULE hSensorLib = LoadLibrary (SAMSUNG_SENSOR_DLL);if (NULL == hSensorLib){      
  3. printf("Unable to load Samsung Sensor DLL\n");      
  4. throw std::runtime_error("Unable to load Samsung Sensor DLL");}  
  5. pfnSmiAccelerometerGetVector = (PFN_SmiAccelerometerGetVector)      
  6. GetProcAddress(hSensorLib, L"SmiAccelerometerGetVector");pfnSmiAccelerometerGetCapabilities = (PFN_SmiAccelerometerGetCapabilities)      
  7. GetProcAddress(hSensorLib, L"SmiAccelerometerGetCapabilities");pfnSmiAccelerometerRegisterHandler = (PFN_SmiAccelerometerRegisterHandler)      
  8. GetProcAddress(hSensorLib, L"SmiAccelerometerRegisterHandler");pfnSmiAccelerometerUnregisterHandler = (PFN_SmiAccelerometerUnregisterHandler)     
  9. GetProcAddress(hSensorLib, L"SmiAccelerometerUnregisterHandler");if (NULL == pfnSmiAccelerometerGetVector){    printf("Unable to find entry point of SmiAccelerometerGetVector\n");      
  10. throw std::runtime_error("Unable to find entry point of SmiAccelerometerGetVector");}if (NULL == pfnSmiAccelerometerGetCapabilities){      
  11. printf("Unable to find entry point of SmiAccelerometerGetCapabilities\n");      
  12. throw std::runtime_error("Unable to find entry point of SmiAccelerometerGetCapabilities");}if (NULL == pfnSmiAccelerometerRegisterHandler){      
  13. printf("Unable to find entry point of SmiAccelerometerRegisterHandler\n");      
  14. throw std::runtime_error("Unable to find entry point of SmiAccelerometerRegisterHandler");}if (NULL == pfnSmiAccelerometerUnregisterHandler){      
  15. printf("Unable to find entry point of SmiAccelerometerUnregisterHandler\n");      
  16. throw std::runtime_error("Unable to find entry point of SmiAccelerometerUnregisterHandler");} 

LoadLibrary()函數(shù)動(dòng)態(tài)加載DLL,GetProcAddress()根據(jù)函數(shù)的名字 加載函數(shù)的入口地址 到指向函數(shù)的指針。有點(diǎn)繞口,sorry。如果地址不為空,那么可以根據(jù)這個(gè)地址調(diào)用相應(yīng)的函數(shù)。

調(diào)用函數(shù)

調(diào)用函數(shù)的方法和靜態(tài)加載DLL的方法一樣,但是不是直接調(diào)用函數(shù)的名字,而是使用指向函數(shù)的指針來調(diào)用,下面的例子可以和靜態(tài)加載DLL函數(shù)調(diào)用的例子對(duì)比來看。

 
 
 
  1. SmiAccelerometerCapabilities cap;   
  2. if( pfnSmiAccelerometerGetCapabilities(&cap) != SMI_SUCCESS)  
  3.  {      
  4. throw;}SmiAccelerometerHandler h = &GetVectorHandler;  
  5. if(pfnSmiAccelerometerRegisterHandler(1000, h) != SMI_SUCCESS)  
  6. {    throw;} 

C++動(dòng)態(tài)加載DLL的方法就完成了。

.NET的世界

下面這段表述不對(duì),請(qǐng)看下面的回復(fù)。.NET使用DllImport屬性進(jìn)行P/Invoke不應(yīng)該叫做動(dòng)態(tài)加載,因?yàn)椴荒苄遁d,應(yīng)該叫做按需加載,就是在call這個(gè)函數(shù)的時(shí)候才加載,而不是在程序啟動(dòng)的時(shí)候加載。按需加載和靜態(tài)加載的區(qū)別是加載的時(shí)間不一樣。

{

在.NET里面P/Invoke一個(gè)DLL里面的函數(shù)全部都是動(dòng)態(tài)加載(這是錯(cuò)的,謝謝Wuya指出,這里應(yīng)該叫做按需加載,動(dòng)態(tài)加載的方法可以見Wuya到回復(fù))的,使用DllImport屬性來定義。如果SmiAccelerometerUnregisterHandler()函數(shù)使用在.NET下會(huì)定義如下:

[DllImport("SamsungMobileSDK_1.dll", CharSet = CharSet.Auto, SetLastError = true)]private static extern uint SmiAccelerometerUnregisterHandler();使用.NET比使用Native C++動(dòng)態(tài)加載相對(duì)簡(jiǎn)單。

}

關(guān)于Mobile Sensors API項(xiàng)目

這個(gè)項(xiàng)目還是在起步階段,當(dāng)前實(shí)現(xiàn)了samsung的重力感應(yīng)器,我把項(xiàng)目host到 Mobile Sensors API - Native unified APIs for Windows Mobile Sensors 了,我會(huì)持續(xù)改進(jìn),把各種sensors的實(shí)現(xiàn)到這個(gè)項(xiàng)目中。

源代碼:http://mobilesensor.codeplex.com/SourceControl/ListDownloadableCommits.aspx

環(huán)境:VS2008 + WM 6 professional SDK + Samsung Windows Mobile SDK


文章標(biāo)題:淺析C++動(dòng)態(tài)加載DLL在Windows Mobile下實(shí)現(xiàn)
分享地址:http://www.dlmjj.cn/article/cospcss.html