在作为泛型传递的字典上迭代
本文关键字:字典 迭代 泛型 | 更新日期: 2023-09-27 17:54:36
我在尝试迭代传递给函数作为泛型的字典时遇到了麻烦。例如,我有一个从数据库加载数据的函数。
public T Load<T>(...)
这个函数可以像这样调用,我没有问题;
someclasstype data = Load<someclasstype>(...);
List<someclasstype> data = Load<List<someclasstype>>(...);
我最近尝试将其扩展为能够处理字典,并像这样调用它:
Dictionary<long, someclasstype> data = Load<Dictionary<long, someclasstype>>(...)
我可以毫无问题地加载数据并将其存储在字典中。
在这个阶段,字典及其所有键值对都存储在一个名为result的变量中,我用 创建了一个IEnumerable。IEnumerator resultIdx = ((IEnumerable)result).GetEnumerator();
if (!resultIdx.MoveNext())
return (T)result;
object kvp = resultIdx.Current;
到目前为止一切顺利。我可以看到键的值和表中值的值,或者通过鼠标悬停在kvp变量上。
但是我不知道如何从kvp获得keyvaluepair的值部分。
// None of these work - I get compile time errors, unboxing errors, or invalid cast errors.
object item = ((KeyValuePair<TKey, TValue>)kvp).Value;
object item = ((KeyValuePair<long, object>)kvp).Value;
object item = ((T)kvp).Value // Never had a hope for this, but desperation...
有谁知道我该怎么做吗?
尝试添加dynamic kvp = resultIdx.Current;
。然后可以使用kvp.Value
您可以将该函数重写为两个函数,如:
public T Load<T>(...)
//Or maybe public List<T> Load<T>(...)
和
public Dictionary<long, T> LoadD<T>(...)
然后可以在LoadD中将结果强制转换为KeyValuePair<long, T>
。您可以从LoadD调用Load来减少代码重写。
Dede在评论中给出的答案:
"使用反射?"
object key kvp.GetType().GetProperty("Key").GetValue(kvp);
object value kvp.GetType().GetProperty("Value").GetValue(kvp);
不是很优化,但可以工作…