P/Invoke 宣告應該是可移植的
更新:2007 年 11 月
型別名稱 |
PInvokeDeclarationsShouldBePortable |
CheckId |
CA1901 |
分類 |
Microsoft.Portability |
中斷變更 |
中斷 - 如果可以在組件 (Assembly) 外部看見 P/Invoke。非中斷 - 如果不能在組件外部看見 P/Invoke。 |
原因
這項規則會評估每個參數的大小和 P/Invoke 的傳回值,並且在 32 位元和 64 位元平台上封送處理至 Unmanaged 程式碼時驗證其大小是否正確。這項規則最常見的違規情形,就是在需要與平台相關之指標大小變數的地方傳遞固定大小的整數。
規則描述
下列任一情況都會引發這項規則:
傳回值或參數的型別應該是 IntPtr,但其型別卻是固定大小的整數。
傳回值或參數的型別應該固定大小的整數,但其型別卻是 IntPtr。
如何修正違規
您可以使用 IntPtr 或 UIntPtr 表示控制代碼 (而不是 Int32 或 UInt32),藉以修正此違規情形。
隱藏警告的時機
您不應該隱藏這項警告。
範例
下列範例示範這項規則的違規情形。
internal class NativeMethods
{
[DllImport("shell32.dll", CharSet=CharSet.Auto)]
internal static extern IntPtr ExtractIcon(IntPtr hInst,
string lpszExeFileName, IntPtr nIconIndex);
}
在這個範例中,nIconIndex 參數宣告為 IntPtr,它在 32 位元平台上是 4 個位元組寬,在 64 位元平台上則是 8 個位元組寬。在接下來的 Unmanaged 宣告中,您會看到 nIconIndex 在所有平台上都是 4 個位元組不帶正負號的整數 (Unsigned Integer)。
HICON ExtractIcon(HINSTANCE hInst, LPCTSTR lpszExeFileName,
UINT nIconIndex);
若要修正此違規情形,請將宣告變更如下:
internal class NativeMethods{
[DllImport("shell32.dll", CharSet=CharSet.Auto)]
internal static extern IntPtr ExtractIcon(IntPtr hInst,
string lpszExeFileName, uint nIconIndex);
}