当method具有Dictionary参数时,Type.InvokeMember

时间:2013-07-01 09:43:05

标签: c# reflection dictionary hashtable invokemember

我正在

  

找不到方法'MyNameSpace.MyClass.MyMethod'。

当我将MyMethod的参数从Hashtable更改为Dictionary<string, string>时。

调用调用是

return = t.InvokeMember("MyMethod", (BindingFlags.DeclaredOnly | BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.InvokeMethod), null, instance, params);

当我这样做时

Type type = a.GetType(String.Concat(DLLName, ".MyClass"));
var methods = t.GetMethods();

methods包含MyMethod()所以它就在那里。

任何人都可以放弃任何光明吗?

params

Object[] params = new Object[11];
...
params[5] = foo.myHashtable.Cast<DictionaryEntry>().ToDictionary(d => d.Key, d => d.Value);   
...

MyMethod签名是

public MyMethodReturn MyMethod(Byte[] m, Hashtable d, Mutex mut, FileStream logFile, Hashtable t, Dictionary<string, Byte[]> fields, bool e, byte[] k, int hashCode, bool h, Byte[] mm)

2 个答案:

答案 0 :(得分:1)

你有:

params[5] = foo.myHashtable.Cast<DictionaryEntry>()
               .ToDictionary(d => d.Key, d => d.Value); 

这会创建一个与签名不匹配的Dictionary<object,object>。这是因为DictionaryEntryobject Key {get;}object Value {get;},编译器正在使用这些来推断字典的类型(泛型类型推断)。

尝试:

params[5] = foo.myHashtable.Cast<DictionaryEntry>()
               .ToDictionary(d => (string)d.Key, d => (byte[])d.Value); 

这将创建一个Dictionary<string,byte[]>,它应匹配。

答案 1 :(得分:0)

Reflection无法找到该方法,因为该方法需要哈希表而不是dictinary,字典不会从哈希表继承,因此您不能使用字典而不是哈希表。方法签名应该在反射可以调用方法之前匹配。