新聞中心
C#調(diào)用Windows API之調(diào)用格式前言:在.Net Framework SDK文檔中,關(guān)于調(diào)用Windows API的指示比較零散,并且其中稍全面一點(diǎn)的是針對Visual Basic .net講述的。本文將C#中調(diào)用API的要點(diǎn)匯集如下,希望給未在C#中使用過API的朋友一點(diǎn)幫助。另外如果安裝了Visual Studio .net的話,在C:\Program Files\Microsoft Visual Studio .NET\FrameworkSDK\Samples\Technologies\Interop\PlatformInvoke\WinAPIs\CS目錄下有大量的調(diào)用API的例子。

成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都做網(wǎng)站、網(wǎng)站建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、互助網(wǎng)絡(luò)推廣、微信平臺小程序開發(fā)、互助網(wǎng)絡(luò)營銷、互助企業(yè)策劃、互助品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供互助建站搭建服務(wù),24小時服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com
C#調(diào)用Windows API之調(diào)用格式
- using System.Runtime.InteropServices;
- //引用此名稱空間,簡化后面的代碼
- ...
- //使用DllImportAttribute特性來引入api函數(shù),
- //注意聲明的是空方法,即方法體為空。
- [DllImport("user32.dll")]
- public static extern ReturnType FunctionName(type arg1,type arg2,...);
- //調(diào)用時與調(diào)用其他方法并無區(qū)別
C#:調(diào)用Windows API之調(diào)用格式細(xì)節(jié)可以使用字段進(jìn)一步說明特性,用逗號隔開,如:
- [ DllImport( "kernel32", EntryPoint="GetVersionEx" )]
C#調(diào)用Windows API之調(diào)用格式之DllImportAttribute特性的公共字段如下:
1、CallingConvention 指示向非托管實(shí)現(xiàn)傳遞方法參數(shù)時所用的 CallingConvention 值。
CallingConvention.Cdecl : 調(diào)用方清理堆棧。它使您能夠調(diào)用具有 varargs 的函數(shù)。
CallingConvention.StdCall : 被調(diào)用方清理堆棧。它是從托管代碼調(diào)用非托管函數(shù)的默認(rèn)約定。
2、CharSet 控制調(diào)用函數(shù)的名稱版本及指示如何向方法封送 String 參數(shù)。
此字段被設(shè)置為 CharSet 值之一。如果 CharSet 字段設(shè)置為 Unicode,則所有字符串參數(shù)在傳遞到非托管實(shí)現(xiàn)之前都轉(zhuǎn)換成 Unicode 字符。這還導(dǎo)致向 DLL EntryPoint 的名稱中追加字母“W”。如果此字段設(shè)置為 Ansi,則字符串將轉(zhuǎn)換成 ANSI 字符串,同時向 DLL EntryPoint 的名稱中追加字母“A”。
大多數(shù) Win32 API 使用這種追加“W”或“A”的約定。如果 CharSet 設(shè)置為 Auto,則這種轉(zhuǎn)換就是與平臺有關(guān)的(在 Windows NT 上為 Unicode,在 Windows 98 上為 Ansi)。CharSet 的默認(rèn)值為 Ansi。CharSet 字段也用于確定將從指定的 DLL 導(dǎo)入哪個版本的函數(shù)。
CharSet.Ansi 和 CharSet.Unicode 的名稱匹配規(guī)則大不相同。對于 Ansi 來說,如果將 EntryPoint 設(shè)置為“MyMethod”且它存在的話,則返回“MyMethod”。如果 DLL 中沒有“MyMethod”,但存在“MyMethodA”,則返回“MyMethodA”。
對于 Unicode 來說則正好相反。如果將 EntryPoint 設(shè)置為“MyMethod”且它存在的話,則返回“MyMethodW”。如果 DLL 中不存在“MyMethodW”,但存在“MyMethod”,則返回“MyMethod”。如果使用的是 Auto,則匹配規(guī)則與平臺有關(guān)(在 Windows NT 上為 Unicode,在 Windows 98 上為 Ansi)。如果 ExactSpelling 設(shè)置為 true,則只有當(dāng) DLL 中存在“MyMethod”時才返回“MyMethod”。
3、EntryPoint 指示要調(diào)用的 DLL 入口點(diǎn)的名稱或序號。
如果你的方法名不想與api函數(shù)同名的話,一定要指定此參數(shù),例如:
- [DllImport("user32.dll",
- CharSet="CharSet.Auto",EntryPoint="MessageBox")]
- public static extern int MsgBox(
- IntPtr hWnd,string txt,string caption, int type);
4、ExactSpelling 指示是否應(yīng)修改非托管 DLL 中的入口點(diǎn)的名稱,以與 CharSet 字段中指定的 CharSet 值相對應(yīng)。如果為 true,則當(dāng) DllImportAttribute.CharSet 字段設(shè)置為 CharSet 的 Ansi 值時,向方法名稱中追加字母 A,當(dāng) DllImportAttribute.CharSet 字段設(shè)置為 CharSet 的 Unicode 值時,向方法的名稱中追加字母 W。此字段的默認(rèn)值是 false。
5、PreserveSig 指示托管方法簽名不應(yīng)轉(zhuǎn)換成返回 HRESULT、并且可能有一個對應(yīng)于返回值的附加 [out, retval] 參數(shù)的非托管簽名。
6、SetLastError 指示被調(diào)用方在從屬性化方法返回之前將調(diào)用 Win32 API SetLastError。 true 指示調(diào)用方將調(diào)用 SetLastError,默認(rèn)為 false。運(yùn)行時封送拆收器將調(diào)用 GetLastError 并緩存返回的值,以防其被其他 API 調(diào)用重寫。用戶可通過調(diào)用 GetLastWin32Error 來檢索錯誤代碼。
C#調(diào)用Windows API之調(diào)用格式相關(guān)的內(nèi)容就向你介紹到這里,希望對你了解和學(xué)習(xí)C#調(diào)用Windows API之調(diào)用格式有所幫助。
【編輯推薦】
- C# Windows CE特點(diǎn)之模塊化
- C# Windows CE特點(diǎn)之可移植性
- C# Windows CE特點(diǎn)之兼容性
- C# Windows CE特點(diǎn)之可連接性
- C# Windows CE特點(diǎn)之實(shí)時性
本文標(biāo)題:C#調(diào)用Windows API之調(diào)用格式淺析
分享路徑:http://m.5511xx.com/article/ccsiecg.html


咨詢
建站咨詢
