我想在某些方面(或两者)Delegate
或MethodInfo
有资格这个称号。但是,既没有提供我正在寻找的语法好处。因此,简而言之,有没有一些办法,我可以写:函数指针在C#
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.");
}
}
虽然我认为你是一个思考这个问题的天才,但我在尝试使用以下代码创建委托时遇到了绑定错误:return(DynamicFunction)Delegate。CreateDelegate(typeof(DynamicFunction), \t \t \t \t this,functions [function]); – 2009-07-26 11:43:04
这很复杂......挂在上面。 – 2009-07-26 11:45:53