我正在
找不到方法'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)
答案 0 :(得分:1)
你有:
params[5] = foo.myHashtable.Cast<DictionaryEntry>()
.ToDictionary(d => d.Key, d => d.Value);
这会创建一个与签名不匹配的Dictionary<object,object>
。这是因为DictionaryEntry
有object 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,字典不会从哈希表继承,因此您不能使用字典而不是哈希表。方法签名应该在反射可以调用方法之前匹配。