Aracılığıyla paylaş


Marshal.GetLastPInvokeError Yöntem

Tanım

Geçerli iş parçacığında son platform çağırma hatasını alın.

public:
 static int GetLastPInvokeError();
public static int GetLastPInvokeError ();
static member GetLastPInvokeError : unit -> int
Public Shared Function GetLastPInvokeError () As Integer

Döndürülenler

Son platform çağırma hatası.

Örnekler

Aşağıdaki örnek, olarak ayarlanmış true bir p/invoke DllImportAttribute.SetLastError tanımlar ve son p/invoke hatasını almak için komutunu GetLastPInvokeError gösterir.

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}");
    }
}

Açıklamalar

Son platform çağırma hatası, ile yapılandırılan en son platform çağrısı tarafından DllImportAttribute.SetLastError ayarlanan hataya true veya en son gerçekleşen çağrısına SetLastPInvokeError(Int32)karşılık gelir.

Bu yöntem yalnızca belirtilen senaryolar aracılığıyla ayarlanan hataları döndürür. Platform çağırma kullanımından bağımsız olarak son sistem hatasını almak için kullanın GetLastSystemError.

Bu yöntem işlevsel olarak ile GetLastWin32Erroreşdeğerdir. API'nin amacını ve platformlar arası doğasını daha iyi yansıtacak şekilde adlandırılır. GetLastPInvokeError yerine GetLastWin32Errortercih edilmelidir.

Şunlara uygulanır