将反射与标准调用混合

时间:2013-09-27 19:19:18

标签: c# reflection

让我先说一下,我完全不喜欢反思。

我有Dictionary stringFunc<string, string>。我想添加一个配置部分,允许我定义可以通过编程方式添加到此字典中的静态方法的名称。

所以基本上,我会有这样的事情:

public static void DoSomething()
{
    string MethodName = "Namespace.Class.StaticMethodName";

    // Somehow convert MethodName into a Func<string, string> object that can be 
    // passed into the line below

    MyDictionary["blah"] = MethodNameConvertedToAFuncObject;
    MyDictionary["foo"] = ANonReflectiveMethod;

    foreach(KeyValuePair<string, Func<string, string>> item in MyDictionary)
    {
        // Calling method, regardless if it was added via reflection, or not
        Console.WriteLine(item.Value(blah));
    }
}

public static string ANonReflectiveMethod(string AString)
{
    return AString;
}

是否可以这样做,还是我需要通过反射调用所有内容?

1 个答案:

答案 0 :(得分:4)

我认为你所寻找的只是Delegate.CreateDelegate。你需要打破你的名字和方法名称。然后,您可以使用Type.GetType()获取类型,然后使用Type.GetMethod()获取MethodInfo,然后使用:

var func = (Func<string, string>) Delegate.CreateDelegate(
                            typeof(Func<string, string>), methodInfo);

创建委托后,您可以毫无问题地将其放入字典中。

类似于:

static Func<string, string> CreateFunction(string typeAndMethod)
{
    // TODO: *Lots* of validation
    int lastDot = typeAndMethod.LastIndexOf('.');
    string typeName = typeAndMethod.Substring(0, lastDot);
    string methodName = typeAndMethod.Substring(lastDot + 1);
    Type type = Type.GetType(typeName);
    MethodInfo method = type.GetMethod(methodName, new[] { typeof(string) });
    return (Func<string, string>) Delegate.CreateDelegate(
        typeof(Func<string, string>), method);
}

请注意,Type.GetType()只会在当前正在执行的程序集中找到类型或mscorlib,除非您实际指定了程序集限定名称。只是需要考虑的事情。如果您已经知道要在其中找到方法的程序集,则可能需要使用Assembly.GetType()