Прочитать на английском

Поделиться через


ILGenerator.EmitCalli Метод

Определение

Помещает инструкцию Calli в поток MSIL.

Перегрузки

EmitCalli(OpCode, CallingConvention, Type, Type[])

Помещает инструкцию Calli в поток инструкций языка MSIL с указанием соглашений по неуправляемым вызовам для косвенного вызова.

EmitCalli(OpCode, CallingConventions, Type, Type[], Type[])

Помещает инструкцию Calli в поток инструкций языка MSIL с указанием соглашений по управляемым вызовам для косвенного вызова.

EmitCalli(OpCode, CallingConvention, Type, Type[])

Исходный код:
ILGenerator.cs
Исходный код:
ILGenerator.cs
Исходный код:
ILGenerator.cs

Помещает инструкцию Calli в поток инструкций языка MSIL с указанием соглашений по неуправляемым вызовам для косвенного вызова.

public abstract void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Runtime.InteropServices.CallingConvention unmanagedCallConv, Type? returnType, Type[]? parameterTypes);
public virtual void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Runtime.InteropServices.CallingConvention unmanagedCallConv, Type? returnType, Type[]? parameterTypes);
public virtual void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Runtime.InteropServices.CallingConvention unmanagedCallConv, Type returnType, Type[] parameterTypes);
public void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Runtime.InteropServices.CallingConvention unmanagedCallConv, Type returnType, Type[] parameterTypes);

Параметры

opcode
OpCode

Инструкция языка MSIL, которую следует включить в поток. Этот параметр должен содержать значение Calli.

unmanagedCallConv
CallingConvention

Соглашение по неуправляемым вызовам, которое следует использовать.

returnType
Type

Тип (Type) результата.

parameterTypes
Type[]

Типы обязательных аргументов инструкции.

Примеры

В следующем примере кода показано контекстное использование EmitCalli метода для вызова метода неуправляемого типа, внешнего для динамического класса.

MethodBuilder myMthdBuilder = myTypeBuilder.DefineMethod("MyMethod",
                  MethodAttributes.Public,
                  returnType, mthdParamTypes);
                            
// We will assume that an external unmanaged type "LegacyNumber" has been loaded, and
// that it has a method "ToString" which returns a string.

MethodInfo unmanagedMthdMI = Type.GetType("LegacyNumber").GetMethod("ToString");
ILGenerator myMthdIL = myMthdBuilder.GetILGenerator();

// Code to emit various IL opcodes here ...

// Load a reference to the specific object instance onto the stack.

myMthdIL.Emit(OpCodes.Ldc_I4, addrOfLegacyNumberObject);
myMthdIL.Emit(OpCodes.Ldobj, Type.GetType("LegacyNumber"));

// Make the call to the unmanaged type method, telling it that the method is
// the member of a specific instance, to expect a string
// as a return value, and that there are no explicit parameters.
myMthdIL.EmitCalli(OpCodes.Calli,
           System.Runtime.InteropServices.CallingConvention.ThisCall,
               typeof(string),
           new Type[] {});

// More IL code emission here ...

Комментарии

Используйте , EmitCalli чтобы поместить инструкцию Calli в поток. Не используйте Emit.

Применяется к

.NET 10 и другие версии
Продукт Версии
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.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 2.1

EmitCalli(OpCode, CallingConventions, Type, Type[], Type[])

Исходный код:
ILGenerator.cs
Исходный код:
ILGenerator.cs
Исходный код:
ILGenerator.cs

Помещает инструкцию Calli в поток инструкций языка MSIL с указанием соглашений по управляемым вызовам для косвенного вызова.

public abstract void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Reflection.CallingConventions callingConvention, Type? returnType, Type[]? parameterTypes, Type[]? optionalParameterTypes);
public virtual void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Reflection.CallingConventions callingConvention, Type? returnType, Type[]? parameterTypes, Type[]? optionalParameterTypes);
public virtual void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Reflection.CallingConventions callingConvention, Type returnType, Type[] parameterTypes, Type[] optionalParameterTypes);
public void EmitCalli(System.Reflection.Emit.OpCode opcode, System.Reflection.CallingConventions callingConvention, Type returnType, Type[] parameterTypes, Type[] optionalParameterTypes);

Параметры

opcode
OpCode

Инструкция языка MSIL, которую следует включить в поток. Этот параметр должен содержать значение Calli.

callingConvention
CallingConventions

Соглашение по управляемым вызовам, которое следует использовать.

returnType
Type

Тип (Type) результата.

parameterTypes
Type[]

Типы обязательных аргументов инструкции.

optionalParameterTypes
Type[]

Типы необязательных аргументов для вызовов varargs.

Исключения

optionalParameterTypes не является null, однако callingConvention не содержит флаг VarArgs.

Комментарии

Используйте , EmitCalli чтобы поместить инструкцию Calli в поток. Не используйте Emit.

Если optionalParameterTypes указывает необязательные аргументы, callingConvention необходимо включить CallingConventions.VarArgs флаг .

Применяется к

.NET 10 и другие версии
Продукт Версии
.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, 10
.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 2.0 (package-provided), 2.1