C#使用DllImport調(diào)用非托管的代碼的方法
找到GetShortPathName的方法簽名,
DWORD GetShortPathName(LPCTSTR tpszLongPath,TPTSTR lpszShortPath,DWORD cchBuffer);
非托管及托管數(shù)據(jù)類型對應(yīng)關(guān)系:
LPCTSTR String
LPTSTR StringBuilder
DWORD int
DllImport的導(dǎo)入規(guī)則:
1、方法名與Win API完全一樣。如果在C#中調(diào)用時顯示完全不同的方法名稱,則需要引入EntryPoint屬性,使用別名顯示。
2、函數(shù)除需要DllImport類修飾符外,還需要聲明public static extern類型。
3、函數(shù)返回值和參數(shù)必須和調(diào)用的API的完全一樣。
4、必須引入System.Runtime.InteropServices命名空間。
代碼:
using System.Runtime.InteropServices;
public class Test
{
[DllImport("kernel32.dll",CharSet=CharSet.Auto,EntryPoint="GetShort")]
public static extern int GetShortPathName(
[MarshalAs(UnmanagedType.LPTStr)] String path,
[MarshalAs(UnmanagedType.LPTStr)] StringBuilder shortPath,
int shortPathLength);
}
代碼調(diào)用中kernel32.dll的路徑之所以沒寫是因為DllImport會按照以下三種順序查找Dll:
1、exe所在目錄;2、System32目錄;3、環(huán)境變量目錄。
MarshalAs為可選類型,因為每個數(shù)據(jù)類型都有默認的封送行為,該屬性指示如何在托管代碼和非托管代碼之間的封送數(shù)據(jù),可將該屬性用于參數(shù)、字段和返回值。大多數(shù)情況下該屬性只是用UnmanagedType枚舉類型就能滿足大多數(shù)非托管的數(shù)據(jù)類型,如默認情況下字符會被當作BStr傳入到Dll中,可以使用MarshalAs將字符串指定為LPTStr、LPWStr或LPStr等。
DllImport可選屬性解釋
EntryPoint 可對方法采用不同的名稱,使用別名
CharSet 函數(shù)調(diào)用使用Unicode還是Ansi
ExactSpelling False,表示讓編譯器自己選擇使用Unicode或Ansi
CallingConvetnion 它的參數(shù)指示入口點調(diào)用的約定;不指定默認為CallingConvention.WinAPI
PreserveSig 指示方法簽名應(yīng)當被保留還是被轉(zhuǎn)換,當被轉(zhuǎn)換時它被轉(zhuǎn)換為一個具有HRESULT返回值和該返回值的一個名為retval的附加輸出參數(shù)的簽名,默認為true。
SetLastError 指定是否保留上一次錯誤,默認為false
相關(guān)文章
在WinForm中發(fā)送HTTP請求的實現(xiàn)方法
下面小編就為大家?guī)硪黄赪inForm中發(fā)送HTTP請求的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06
C#中32位浮點數(shù)Float(Real)一步步按位Bit進行分析
這篇文章主要介紹了C#中32位浮點數(shù)Float(Real)一步步按位Bit進行分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08

