При составлении дерево экспрессии лямбда всегда добавляет system.runtime.compilerservices.closureC#

Место общения программистов C#
Ответить
Anonymous
 При составлении дерево экспрессии лямбда всегда добавляет system.runtime.compilerservices.closure

Сообщение Anonymous »

Я выполняю различные операции с поведением метода Uodate во время выполнения с использованием экспрессионных деревьев. < /p>

Когда сделано с компиляцией, я могу иметь доступ к стандартным делегатам, но полученный метод, который мне нужно снова задуматься), всегда добавляет параметр типа < /p>

System.Runtime.CompilerServices.Closure
< /code>

как первый аргумент.class Program
{
public static float SimpleOperation(float f1, float f2)
{
return f1 + f2;
}

public static LambdaExpression WrapSelf(MethodInfo methodInfo)
{
var parameterInfoList = methodInfo.GetParameters();
ParameterExpression[] wrappedParameters = new ParameterExpression[parameterInfoList.Length];

for (int i = 0; i < parameterInfoList.Length; i++)
{
var parameterInfo = parameterInfoList;
ParameterExpression inputParam = Expression.Parameter(parameterInfo.ParameterType, parameterInfo.Name);
wrappedParameters = inputParam;
}

Expression funcCall = Expression.Call(methodInfo, wrappedParameters.ToArray());
return Expression.Lambda(funcCall, wrappedParameters);
}

static void Main(string[] args)
{
MethodInfo methodToWrap = typeof(Program).GetMethod("SimpleOperation", BindingFlags.Public | BindingFlags.Static);

var lambdaExpression = WrapSelf(methodToWrap);

Func wrappedAddDelegate = (Func)lambdaExpression.Compile();

MethodInfo resultMethodInfo = wrappedAddDelegate.Method;

var info = resultMethodInfo.GetParameters()[0];

Console.ReadLine();
}

}
< /code>

Так что теперь все это правильно компилируется и выполняет: < /p>

float f = wrappedAddDelegate(2.0f,3.0f);
< /code>

Возвращает 5, как и ожидалось < /p>

Теперь проблема в том, что Resultmethodinfo теперь имеет 3 параметра (первым является закрытие), поэтому подпись теперь < /p>

(Closure,float,float) -> float
< /code>

Поэтому, если я попытаюсь использовать эту информацию о методе для дальнейшего размышления, это имеет тенденцию испортить вещи. < /p>

Есть ли способ выполнить ту же задачу, но избавиться от типа закрытия в результате, поэтому информация о нашем методе должна сохранять одинаковую подпись, например: < /p>

(float, float) -> float
< /code>

Я знаю, что вместо этого можно выполнить это, используя отражение.>

Подробнее здесь: https://stackoverflow.com/questions/512 ... lerservice
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»