c#使用指針_第1頁
已閱讀1頁,還剩2頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、C#中調(diào)用C的dll的參數(shù)為指針類型的導(dǎo)出函數(shù)點(diǎn)擊:發(fā)布日期:20076287:29:00進(jìn)入論壇嚴(yán)格來說這篇文章算不上C范圍的,不過還是掛了點(diǎn)邊,還是在自己的blog中記錄一下吧。C中使用指針是家常便飯了,也非常的好用,這也是我之所以喜歡C的原因之一。但是在C#中就強(qiáng)調(diào)托管的概念了,指針就不用想了。本來如果就在C#的世界里面寫代碼,也還算舒服,但是萬事萬物總有聯(lián)系,這不,現(xiàn)在公司的另外一個用C#作的項(xiàng)目就碰到問題了,要調(diào)用之前用C寫的

2、一個DLL中的一些函數(shù),很多函數(shù)的參數(shù)都是指針類型的,這下可麻煩咯,公司里做C#的都是剛起步,C又只有我最熟悉,這項(xiàng)技術(shù)研究工作又光榮的落到我身上。我對C#也不甚熟悉,所以也許我的方法不一定是最直接的,但是測試的結(jié)果是滿足了這個調(diào)用需要了的。下面我就詳細(xì)介紹一下。使用unsafe、fix等關(guān)鍵字應(yīng)該是能夠?qū)崿F(xiàn)的,但是他們項(xiàng)目組要求不用這個,所以我也沒深入去試驗(yàn)。除了這個方法,應(yīng)該來說是有兩個思路的,第一個思路可能看起來比較直接,使用re

3、f,ref這個關(guān)鍵字似乎有點(diǎn)特殊性,字面上理解似乎應(yīng)該和C中的引用類型相對應(yīng),不過似乎它還是有一定特殊性的,貌似以前看到過一篇文章說ref會自己去判斷是引用類型還是指針,我嘗試了一下,果然是可行的。但是對于有二級指針的情況ref也就不靈了~這就導(dǎo)出了我的另一個思路,使用Marshal。下面我們還是代碼說明問題:以下是CDLL中的代碼片斷,主要是使用到的兩個結(jié)構(gòu)的定義,以及導(dǎo)出函數(shù)TestFunction的定義。CDLL中的代碼片斷#pr

4、agmapack(push)#pragmapack(1)typedefstructEmmStructintlenEMMSTRUCTLPEMMSTRUCTtypedefstructMyStructintiParamlongsizeLPEMMSTRUCTlpEmmStructArrMYSTRUCTLPMYSTRUCT#pragmapack(pop)extern“C“void__declspec(dllexpt)__stdcallTestFu

5、nction(LPMYSTRUCTlpMyStruct)lpMyStructiParam=100lpMyStructsize=10lpMyStructlpEmmStructArr=newEMMSTRUCT[lpMyStructsize]s=(MyStruct)Marshal.PtrToStructure(ptrtypeof(MyStruct))EmmStructretf(inti=0is.sizei)IntPtrptr2=newIntP

6、tr(s.ptrEmmStruct.ToInt32()4i)ret=(EmmStruct)Marshal.PtrToStructure(ptr2typeof(EmmStruct))Marshal.FreeHGlobal(ptr)catch(Exceptione)stringstr=e.Messagefinally代碼也不多,而且從字面的意思就能知道是干什么的了,所以我就沒寫注釋。用這種方法就實(shí)現(xiàn)了參數(shù)中含有二級指針的情況。要注意的就是C

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論