委托任何方法类型 - C#

时间:2013-04-02 18:31:29

标签: c# generics reflection delegates method-signature

我想要一个可以执行任何外部方法的类,如下所示:

class CrazyClass
{
  //other stuff

  public AnyReturnType Execute(AnyKindOfMethod Method, object[] ParametersForMethod)
  {
    //more stuff
    return Method(ParametersForMethod) //or something like that
  }
}

这可能吗?是否有代理人采用任何方法签名?

4 个答案:

答案 0 :(得分:29)

您可以通过Func<T>和闭包:

以不同的方式执行此操作
public T Execute<T>(Func<T> method)
{
   // stuff
   return method();
}

然后调用者可以使用闭包来实现它:

var result = yourClassInstance.Execute(() => SomeMethod(arg1, arg2, arg3));

这里的优点是你允许编译器为你做艰苦的工作,方法调用和返回值都是类型安全的,提供intellisense等。

答案 1 :(得分:3)

有点取决于你为什么要首先这样做...我会使用Func泛型做到这一点,以便CrazyClass仍然可以不知道参数。

class CrazyClass
{
    //other stuff

    public T Execute<T>(Func<T> Method)
    {
        //more stuff
        return Method();//or something like that
    }


}

class Program
{
    public static int Foo(int a, int b)
    {
        return a + b;
    }
    static void Main(string[] args)
    {
        CrazyClass cc = new CrazyClass();
        int someargs1 = 20;
        int someargs2 = 10;
        Func<int> method = new Func<int>(()=>Foo(someargs1,someargs2));
        cc.Execute(method);
        //which begs the question why the user wouldn't just do this:
        Foo(someargs1, someargs2);
    }
}

答案 2 :(得分:2)

我认为你最好在这种情况下使用反射,因为你会得到你在问题中所要求的 - 任何方法(静态或实例),任何参数:

public object Execute(MethodInfo mi, object instance = null, object[] parameters = null)
{
    return mi.Invoke(instance, parameters);
}

它的System.Reflection.MethodInfo课程。

答案 3 :(得分:0)

public static void AnyFuncExecutor(Action a)
{
    try
    {
        a();
    }
    catch (Exception exception)
    {
        throw;
    }
}