Я полагаю, что в некотором смысле либо (или оба) Delegate
, либо MethodInfo
могут претендовать на этот титул. Однако ни то, ни другое не обеспечивают синтаксической привлекательности, которую я ищу. Итак, короче говоря, есть ли способ, которым я могу написать следующее:
FunctionPointer foo = // whatever, create the function pointer using mechanisms
foo();
Я не могу использовать твердый делегат (т.е. используя ключевое слово Delegate
, чтобы объявить тип делегата), потому что нет способа узнать до времени выполнения список точных параметров. Для справки, вот что я сейчас играл в LINQPad, где B
будет (в основном) сгенерированным пользователем кодом, и поэтому будет Main
и, следовательно, для моих пользователей, я пытаюсь удалить .Call
:
void Main()
{
A foo = new B();
foo["SomeFuntion"].Call();
}
// Define other methods and classes here
interface IFunction {
void Call();
void Call(params object[] parameters);
}
class A {
private class Function : IFunction {
private MethodInfo _mi;
private A _this;
public Function(A @this, MethodInfo mi) {
_mi = mi;
_this = @this;
}
public void Call() { Call(null); }
public void Call(params object[] parameters) {
_mi.Invoke(_this, parameters);
}
}
Dictionary<string, MethodInfo> functions = new Dictionary<string, MethodInfo>();
public A() {
List<MethodInfo> ml = new List<MethodInfo>(this.GetType().GetMethods());
foreach (MethodInfo mi in typeof(Object).GetMethods())
{
for (int i = 0; i < ml.Count; i++)
{
if (ml[i].Name == mi.Name)
ml.RemoveAt(i);
}
}
foreach (MethodInfo mi in ml)
{
functions[mi.Name] = mi;
}
}
public IFunction this[string function] {
get {
if (!functions.ContainsKey(function))
throw new ArgumentException();
return new Function(this, functions[function]);
}
}
}
sealed class B : A {
public void SomeFuntion() {
Console.WriteLine("SomeFunction called.");
}
}