CallingConvention Enumerazione

Definizione

Specifica la convenzione di chiamata necessaria per chiamare i metodi implementati nel codice non gestito.

C#
public enum CallingConvention
C#
[System.Serializable]
public enum CallingConvention
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum CallingConvention
Ereditarietà
CallingConvention
Attributi

Campi

Nome Valore Descrizione
Cdecl 2

Il chiamante esegue la pulizia dello stack. Questa operazione attiva funzioni chiamanti con varargs, pertanto può essere utilizzata per metodi che accettano un numero variabile di parametri, ad esempio Printf.

FastCall 5

Questa convenzione di chiamata non è supportata.

StdCall 3

Il chiamato esegue la pulizia dello stack.

ThisCall 4

Il primo parametro è il puntatore this ed è archiviato in ECX del Registro di sistema. Altri parametri vengono inseriti nello stack. Questa convenzione di chiamata viene utilizzata per chiamare metodi su classi esportate da una DLL non gestita.

Winapi 1

Questo membro non è in realtà una convenzione chiamante, ma usa invece la convenzione di chiamata alla piattaforma predefinita.

Esempio

Nell'esempio seguente viene illustrato come applicare la Cdecl convenzione di chiamata, che è necessario usare perché lo stack viene pulito dal chiamante.

C#
using System;
using System.Runtime.InteropServices;

internal static class NativeMethods
{
    // C# doesn't support varargs so all arguments must be explicitly defined.
    // CallingConvention.Cdecl must be used since the stack is
    // cleaned up by the caller.

    // int printf( const char *format [, argument]... )

    [DllImport("msvcrt.dll", CharSet = CharSet.Unicode, CallingConvention = CallingConvention.Cdecl)]
    internal static extern int printf(String format, int i, double d);

    [DllImport("msvcrt.dll", CharSet = CharSet.Unicode, CallingConvention = CallingConvention.Cdecl)]
    internal static extern int printf(String format, int i, String s);
}

public class App
{
    public static void Main()
    {
        NativeMethods.printf("\nPrint params: %i %f", 99, 99.99);
        NativeMethods.printf("\nPrint params: %i %s", 99, "abcd");
    }
}

Commenti

Usare sempre l'enumerazione anziché l'enumerazione CallingConventionCALLCONV per specificare una convenzione di chiamata nel codice gestito. Quest'ultimo esiste solo per motivi di definizioni COM. L'enumerazione CallingConvention viene usata da DllImportAttribute e diverse classi in System.Reflection.Emit per generare dinamicamente le firme della piattaforma.

Si applica a

Prodotto Versioni
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Vedi anche