溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何改寫VB.NET內(nèi)存指針

發(fā)布時間:2021-12-02 10:47:28 來源:億速云 閱讀:166 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“如何改寫VB.NET內(nèi)存指針”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“如何改寫VB.NET內(nèi)存指針”這篇文章吧。

近日心血來潮,花巨資購進(jìn)多普達(dá)智能手機一臺, 系統(tǒng)為微軟的Smartphone2003 ,由于對"瘟倒死"操作系統(tǒng)的熟悉,很快已步入正軌,各種圖片、程序安裝了一大堆后,開始發(fā)揮自己的程序特長,試著為愛機寫一個資源管理器的簡單程序。

我選擇的編程工具當(dāng)然是Visual Basic NET2003,實話說Microsoft .NET Framework SDK 提供的功能實在不感恭維,微軟好象又要將所有走上光明大道的.NET程序員拖入API的黑暗時代,指針、句柄、地址操作,最令人惱火就是沒有為VB.NET程序做WinCE的API 聲明(令人懷念VB6的API瀏覽器)很快我就在如何啟動手機中的應(yīng)用程序的代碼上困住了,Net沒有為WinCE提供Process 對象這種不付責(zé)任的做法害得我好苦?。?/p>

開始時聲明時老是將ShellExecuteEx 和CreateProcess這兩個熟悉得不能再熟悉的Win32在VB 6中的聲明直接粘到程序中,僅是將VB6的long改為NET的int32,結(jié)果老是報錯。在網(wǎng)上查了N天資料,才發(fā)現(xiàn)原來Win CE的核心API都是在一個coredll.dll文件中,使得我差點沒氣死!還有一點是SHELLEXECUTEINFO結(jié)構(gòu)中的lpFile這種指向字符串常量的指針由于字符的編碼問題不能象在Win32編程中簡單聲明為String類型,所在必須聲明為Intptr,這樣問題就出現(xiàn)了,使用 ShellExecuteEx函數(shù)必須使用微軟在VB.NET中不直接提供的指針操作,所以我只好根據(jù)網(wǎng)上的資料改寫了一個對VB.NET內(nèi)存指針的封裝類,詳細(xì)代碼及解釋如下(新建一個模塊,將以下代碼粘貼進(jìn)去即可使用):

  1. Imports System.Runtime.InteropServices '引及Net框架中對底層操作支持的命名空間  

  2. Public Class clsDAMSMobileMarshal '我寫的內(nèi)存管理類  

  3. #Region "與內(nèi)存有關(guān)的API聲明"  

  4. REM 以下是與內(nèi)存有關(guān)的移動設(shè)備API  

  5. Public Declare Function LocalAlloc Lib "coredll.dll" Alias "LocalAlloc" 
    (ByVal wFlags As Int32, _ByVal wBytes As Int32) As IntPtr  

  6. Public Declare Function LocalFree Lib "coredll.dll" Alias "LocalFree" 
    (ByVal hMem As Int32) As Int32  

  7. Public Declare Function LocalLock Lib "coredll.dll" Alias "LocalLock" 
    (ByVal hMem As Int32) As Int32  

  8. Public Declare Function LocalReAlloc Lib "coredll.dll" Alias "LocalReAlloc" 
    (ByVal hMem As IntPtr, _ByVal wBytes As Int32, ByVal wFlags As Int32) As IntPtr  

  9.  

  10. #End Region  

  11.  

  12. #Region "API常量聲明"  

  13. Public Const LMEM_FIXED = 0 

  14. Public Const LMEM_MOVEABLE = &H2  

  15. Public Const LMEM_ZEROINIT = &H40  

  16. Public Const LPTR = LMEM_FIXED Or LMEM_ZEROINIT  

  17. #End Region  

  18.  

  19. Public Shared Function fnAllocHLocal(ByVal ni_i32Size As Int32) As IntPtr  

  20. '申請本地內(nèi)存,返回一個指向該內(nèi)存塊的指針  

  21. Return LocalAlloc(LPTR, ni_i32Size)  

  22. End Function  

  23.  

  24. Public Shared Function fnFreeHLocal(ByRef ni_pLocal As IntPtr) As Int32  

  25. REM 釋放指定的內(nèi)存塊柄  

  26. Dim ti32FunctionReturnValue As Int32  

  27. If ni_pLocal.Equals(IntPtr.Zero) = False Then  

  28. ti32FunctionReturnValue = (LocalFree(ni_pLocal.ToInt32))  

  29. If ti32FunctionReturnValue = 0 Then  

  30. ni_pLocal = IntPtr.Zero  

  31. End If  

  32. End If  

  33. Return (ti32FunctionReturnValue)  

  34. End Function  

  35.  

  36. Public Shared Function fnReAllocHLocal
    (ByVal ni_pIn As IntPtr, ByVal ni_i32Size As Int32) As IntPtr  

  37. '對指定的內(nèi)存塊重新定義大小  

  38. Return LocalReAlloc(ni_pIn, ni_i32Size, LMEM_MOVEABLE)  

  39. End Function  

  40.  

  41. Public Shared Function fnStringToHLocalUni(ByVal ni_strIn As String) As IntPtr  

  42. '將指定的字符串復(fù)制到一個內(nèi)存塊中,并返回該內(nèi)存塊的指針,這個指針必須使用fnFreeHLocal函數(shù)釋放  

  43. Dim ti32StringBufLength As Int32  

  44. Dim tpTempA As IntPtr  

  45.  

  46. If Not (ni_strIn Is Nothing) Then  

  47. If ni_strIn.Length = 0 Then  

  48. Return IntPtr.Zero  

  49. Else  

  50. ti32StringBufLength = (ni_strIn.Length + 1) * 2 ' 包括***一個中止字符  

  51. tpTempA = fnAllocHLocal(ti32StringBufLength)  

  52. If tpTempA.Equals(IntPtr.Zero) = False Then '申請內(nèi)存成功  

  53. Marshal.Copy(ni_strIn.ToCharArray, 0, tpTempA, ni_strIn.Length)  

  54. Return tpTempA  

  55. End If  

  56. End If  

  57. End If  

  58. End Function  

  59. End Class 

以上是“如何改寫VB.NET內(nèi)存指針”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI