У меня есть проблемы при создании набора делегата, использующего отражение и дженерики.
Я пытаюсь создать набор делегата из методов Ally, чья доля подпись общепринятой методики.
public class Classy
{
public string FirstMethod<T1, T2>( string id, Func<T1, int, IEnumerable<T2>> del );
public string SecondMethod<T1, T2>( string id, Func<T1, int, IEnumerable<T2>> del );
public string ThirdMethod<T1, T2>( string id, Func<T1, int, IEnumerable<T2>> del );
// And so on...
}
И кулинария дженериков:
// This is the Classy's shared method signature
public delegate string classyDelegate<out T1, in T2>( string id, Func<T1, int, IEnumerable<T2>> filter );
// And the linq-way to get the collection of delegates from Classy
(
from method in typeof( Classy ).GetMethods( BindingFlags.Instance | BindingFlags.DeclaredOnly | BindingFlags.NonPublic )
let delegateType = typeof( classyDelegate<,> )
select Delegate.CreateDelegate( delegateType, method )
).ToList( );
Но Delegate.CreateDelegate( delegateType, method )
бросает ArgumentException, говоря Ошибочную привязку к целевому методу.: /
Что я делаю неправильно?
Это потому, что перегрузка Delegate.CreateDelegate поддерживает только создание делегатов, указывающих на статические методы. Если вы хотите выполнить привязку к методам экземпляра, вам также необходимо передать экземпляр, на котором ваш созданный делегат должен вызывать метод.
Вы, вероятно, захотите:
from method in typeof( Classy ).GetMethods( BindingFlags.Instance | BindingFlags.DeclaredOnly | BindingFlags.NonPublic )
let delegateType = typeof( classyDelegate<,> )
select Delegate.CreateDelegate( delegateType, yourInstance, method )
Кроме того, ваш пример кода не будет компилироваться. Вы не можете объявить дисперсию сигнатур методов; и вы не можете пропустить реализацию в не абстрактном классе.
Наконец, Delegate.CreateDelegate создает экземпляр Delegate , который не может существовать, не зная его параметров типа. Следовательно, вы не можете привязаться к classyDelegate <,>, вам нужно знать фактические задействованные типы.