在作为泛型传递的字典上迭代

本文关键字:字典 迭代 泛型 | 更新日期: 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); 

不是很优化,但可以工作…