Aracılığıyla paylaş


CallingConvention Sabit listesi

Tanım

Yönetilmeyen kodda uygulanan yöntemleri çağırmak için gereken çağırma kuralını belirtir.

public enum class CallingConvention
public enum CallingConvention
[System.Serializable]
public enum CallingConvention
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum CallingConvention
type CallingConvention = 
[<System.Serializable>]
type CallingConvention = 
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type CallingConvention = 
Public Enum CallingConvention
Devralma
CallingConvention
Öznitelikler

Alanlar

Cdecl 2

Çağıran yığını temizler. Bu, gibi değişken sayıda parametre Printfkabul eden yöntemler için kullanılmasını uygun hale getiren ile varargsişlevleri çağırmayı etkinleştirir.

FastCall 5

Bu çağırma kuralı desteklenmiyor.

StdCall 3

Arayan, yığını temizler.

ThisCall 4

İlk parametre işaretçidir this ve kayıt ECX'te depolanır. Diğer parametreler yığına gönderilir. Bu çağırma kuralı yönetilmeyen DLL'den dışarı aktarılan sınıflardaki yöntemleri çağırmak için kullanılır.

Winapi 1

Bu üye aslında bir çağırma kuralı değil, bunun yerine varsayılan platform çağırma kuralını kullanır.

Örnekler

Aşağıdaki örnekte, yığın çağıran tarafından temizlendiğinden Cdecl kullanmanız gereken çağrı kuralının nasıl uygulanacağı gösterilmektedir.

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

Açıklamalar

Yönetilen kodda CallingConvention bir çağırma kuralı belirtmek için her zaman numaralandırma yerine CALLCONV numaralandırmayı kullanın. İkincisi yalnızca COM tanımları için mevcuttur. Numaralandırma, CallingConvention platform çağırma imzalarını dinamik olarak yaymak için ve içindeki System.Reflection.Emit birkaç sınıf tarafından DllImportAttribute kullanılır.

Şunlara uygulanır

Ayrıca bkz.