Baca dalam bahasa Inggris

Bagikan melalui


CallingConvention Enum

Definisi

Menentukan konvensi panggilan yang diperlukan untuk memanggil metode yang diterapkan dalam kode yang tidak dikelola.

C#
public enum CallingConvention
C#
[System.Serializable]
public enum CallingConvention
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum CallingConvention
Warisan
CallingConvention
Atribut

Bidang

Nama Nilai Deskripsi
Cdecl 2

Penelepon membersihkan tumpukan. Ini memungkinkan fungsi panggilan dengan varargs, yang membuatnya sesuai untuk digunakan untuk metode yang menerima jumlah variabel parameter, seperti Printf.

FastCall 5

Konvensi panggilan ini tidak didukung.

StdCall 3

Penerima panggilan membersihkan tumpukan.

ThisCall 4

Parameter pertama adalah this pointer dan disimpan dalam register ECX. Parameter lain didorong pada tumpukan. Konvensi panggilan ini digunakan untuk memanggil metode pada kelas yang diekspor dari DLL yang tidak dikelola.

Winapi 1

Anggota ini sebenarnya bukan konvensi panggilan, tetapi sebaliknya menggunakan konvensi panggilan platform default.

Contoh

Contoh berikut menunjukkan cara menerapkan Cdecl konvensi panggilan, yang harus Anda gunakan karena tumpukan dibersihkan oleh pemanggil.

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

Keterangan

Selalu gunakan CallingConvention enumerasi daripada CALLCONV enumerasi untuk menentukan konvensi panggilan dalam kode terkelola. Yang terakhir hanya ada demi definisi COM. CallingConvention Enumerasi digunakan oleh DllImportAttribute dan beberapa kelas untuk System.Reflection.Emit memancarkan platform secara dinamis memanggil tanda tangan.

Berlaku untuk

Produk Versi
.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

Lihat juga