CallingConvention Enumerazione

Definizione

Specifica la convenzione di chiamata necessaria per chiamare i metodi implementati nel codice non gestito.Specifies the calling convention required to call methods implemented in unmanaged code.

public enum class CallingConvention
[System.Runtime.InteropServices.ComVisible(true)]
[System.Serializable]
public enum CallingConvention
type CallingConvention = 
Public Enum CallingConvention
Ereditarietà
CallingConvention
Attributi

Campi

Cdecl 2

Il chiamante esegue la pulizia dello stack.The caller cleans the stack. Questa operazione attiva funzioni chiamanti con varargs, pertanto può essere utilizzata per metodi che accettano un numero variabile di parametri, ad esempio Printf.This enables calling functions with varargs, which makes it appropriate to use for methods that accept a variable number of parameters, such as Printf.

FastCall 5

Questa convenzione di chiamata non è supportata.This calling convention is not supported.

StdCall 3

Il chiamato esegue la pulizia dello stack.The callee cleans the stack. Si tratta della convenzione predefinita per chiamare funzioni non gestite tramite platform invoke.This is the default convention for calling unmanaged functions with platform invoke.

ThisCall 4

Il primo parametro è il puntatore this ed è archiviato in ECX del Registro di sistema.The first parameter is the this pointer and is stored in register ECX. Altri parametri vengono inseriti nello stack.Other parameters are pushed on the stack. Questa convenzione di chiamata viene utilizzata per chiamare metodi su classi esportate da una DLL non gestita.This calling convention is used to call methods on classes exported from an unmanaged DLL.

Winapi 1

In realtà il membro non è una convenzione di chiamata, ma utilizza la convenzione di chiamata predefinita di platform invoke.This member is not actually a calling convention, but instead uses the default platform calling convention. In Windows, ad esempio, l'impostazione predefinita è StdCall, mentre in Windows CE .NET è Cdecl.For example, on Windows the default is StdCall and on Windows CE.NET it is Cdecl.

Esempi

Nell'esempio seguente viene illustrato come applicare la Cdecl convenzione di chiamata, che è necessario utilizzare perché lo stack viene pulito dal chiamante.The following example demonstrates how to apply the Cdecl calling convention, which you must use because the stack is cleaned up by the caller.

using namespace System;
using namespace System::Runtime::InteropServices;

private ref class NativeMethods
{
public:

    // 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)]
    static int printf(String^ format, int i, double d);

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

int main()
{
    NativeMethods::printf("\nPrint params: %i %f", 99, 99.99);
    NativeMethods::printf("\nPrint params: %i %s", 99, "abcd");
}
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");
    }
}
Imports System.Runtime.InteropServices

Friend Class NativeMethods
    ' Visual Basic does not 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)>
    Friend Overloads Shared Function printf(
        ByVal format As String, ByVal i As Integer, ByVal d As Double) As Integer
    End Function

    <DllImport("msvcrt.dll", CharSet:=CharSet.Unicode, CallingConvention:=CallingConvention.Cdecl)>
    Friend Overloads Shared Function printf(
        ByVal format As String, ByVal i As Integer, ByVal s As String) As Integer
    End Function
End Class

Public Class App
    Public Shared Sub Main()
        NativeMethods.printf(ControlChars.CrLf + "Print params: %i %f", 99, 99.99)
        NativeMethods.printf(ControlChars.CrLf + "Print params: %i %s", 99, "abcd")
    End Sub
End Class

Commenti

Usare sempre l' CallingConvention enumerazione anziché l' CALLCONV enumerazione per specificare una convenzione di chiamata nel codice gestito.Always use the CallingConvention enumeration rather than the CALLCONV enumeration to specify a calling convention in managed code. Quest'ultimo esiste solo per le definizioni COM.The latter exists only for the sake of COM definitions. L' CallingConvention enumerazione viene utilizzata da DllImportAttribute e varie classi in System.Reflection.Emit per emettere dinamicamente firme Platform Invoke.The CallingConvention enumeration is used by DllImportAttribute and several classes in System.Reflection.Emit to dynamically emit platform invoke signatures.

Si applica a

Vedi anche