CallingConvention 列挙型

定義

アンマネージ コードで実装されたメソッドを呼び出すために必要な呼び出し規約を指定します。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
継承
CallingConvention
属性

フィールド

Cdecl 2

呼び出し元がスタックを消去します。The caller cleans the stack. これを使用すると、varargs で関数を呼び出すことができます。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

この呼び出し規約はサポートされていません。This calling convention is not supported.

StdCall 3

呼び出し先がスタックを消去します。The callee cleans the stack. これは、プラットフォーム呼び出しでアンマネージ関数を呼び出すための既定の規約です。This is the default convention for calling unmanaged functions with platform invoke.

ThisCall 4

最初のパラメーターは this ポインターで、レジスタ ECX に格納されます。The first parameter is the this pointer and is stored in register ECX. その他のパラメーターは、スタックにプッシュされます。Other parameters are pushed on the stack. この呼び出し規約は、アンマネージ DLL からエクスポートしたクラスのメソッドを呼び出すために使用します。This calling convention is used to call methods on classes exported from an unmanaged DLL.

Winapi 1

このメンバーは実際には呼び出し規約ではありません。代わりに、既定のプラットフォーム呼び出し規約を使用します。This member is not actually a calling convention, but instead uses the default platform calling convention. たとえば、Windows では StdCall、Windows CE .NET では Cdecl が既定値になります。For example, on Windows the default is StdCall and on Windows CE.NET it is Cdecl.

次の例は、呼び出し規約をCdecl適用する方法を示しています。これは、呼び出し元がスタックをクリーンアップするために使用する必要があります。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

注釈

マネージコードでCallingConvention呼び出し規約を指定CALLCONVするには、列挙体ではなく列挙体を常に使用します。Always use the CallingConvention enumeration rather than the CALLCONV enumeration to specify a calling convention in managed code. 後者は、COM 定義のためだけに存在します。The latter exists only for the sake of COM definitions. 列挙体は、およびDllImportAttributeの複数のSystem.Reflection.Emitクラスによって、プラットフォーム呼び出しシグネチャを動的に生成するために使用されます。 CallingConventionThe CallingConvention enumeration is used by DllImportAttribute and several classes in System.Reflection.Emit to dynamically emit platform invoke signatures.

適用対象

こちらもご覧ください