Marshal.GetLastPInvokeError Metod
Definition
Viktigt
En del information gäller för förhandsversionen av en produkt och kan komma att ändras avsevärt innan produkten blir allmänt tillgänglig. Microsoft lämnar inga garantier, uttryckliga eller underförstådda, avseende informationen som visas här.
Hämta det senaste plattformsanropsfelet i den aktuella tråden.
public:
static int GetLastPInvokeError();
public static int GetLastPInvokeError();
static member GetLastPInvokeError : unit -> int
Public Shared Function GetLastPInvokeError () As Integer
Returer
Den senaste plattformen anropar fel.
Exempel
I följande exempel definieras en p/invoke med DllImportAttribute.SetLastError inställd på true och visar hur du använder GetLastPInvokeError för att hämta det sista p/invoke-felet.
using System;
using System.Runtime.InteropServices;
// These functions specify SetLastError=true to propagate the last error from the p/invoke
// such that it can be retrieved using Marshal.GetLastPInvokeError().
internal static class Kernel32
{
[DllImport(nameof(Kernel32), ExactSpelling = true, SetLastError = true)]
internal static extern bool SetCurrentDirectoryW([MarshalAs(UnmanagedType.LPWStr)] string path);
}
internal static class libc
{
[DllImport(nameof(libc), SetLastError = true)]
internal static extern int chdir([MarshalAs(UnmanagedType.LPUTF8Str)] string path);
}
class Program
{
public static void Main(string[] args)
{
// Call p/invoke with valid arguments.
CallPInvoke(AppContext.BaseDirectory);
// Call p/invoke with invalid arguments.
CallPInvoke(string.Empty);
}
private static void CallPInvoke(string path)
{
if (OperatingSystem.IsWindows())
{
Console.WriteLine($"Calling SetCurrentDirectoryW with path '{path}'");
Kernel32.SetCurrentDirectoryW(path);
}
else
{
Console.WriteLine($"Calling chdir with path '{path}'");
libc.chdir(path);
}
// Get the last p/invoke error and display it.
int error = Marshal.GetLastPInvokeError();
Console.WriteLine($"Last p/invoke error: {error}");
}
}
Kommentarer
Det senaste anropsfelet för plattformen motsvarar felet som angetts antingen av den senaste plattformsanropet som konfigurerades med DllImportAttribute.SetLastError inställt true på eller av ett anrop till SetLastPInvokeError(Int32), beroende på vilket som inträffade senast.
Den här metoden returnerar endast fel som anges via de nämnda scenarierna. Om du vill hämta det sista systemfelet oberoende av plattformsanropsanvändning använder du GetLastSystemError.
Den här metoden är funktionellt likvärdig med GetLastWin32Error. Det namnges för att bättre återspegla avsikten med API:et och dess plattformsoberoende karaktär. GetLastPInvokeError bör föredras framför GetLastWin32Error.