实际上我需要像List< KeyValuePair< T,U>>这样的东西.但我希望能够像字典一样初始化它(即每次都不写新的KeyValuePair).像这样:
Dictionary<string,string> dic = new Dictionary<string,string> { { "key1","value1"},{ "key2","value2"} };
解决方法
编辑:事实证明.NET确实已经有一个组合列表/字典类型:
OrderedDictionary
.不幸的是,这是一个非泛型类型,在我看来它没那么吸引人.但是,如果您只是反复调用Add,它会保留插入顺序.
这有点奇怪,因为调用Add不会影响密钥已存在的条目,而使用索引器添加键/值对将覆盖以前的关联.基本上它似乎不是一个非常好的API,我个人仍然会避免它,除非你的用例完全匹配其行为.
不,.NET没有任何插入顺序保留字典.您始终可以使用相关的Add方法编写自己的基于列表的类型.这甚至可能是我考虑扩展现有类型的少数几个地方之一:
public class KeyValueList<TKey,TValue> : List<KeyValuePair<TKey,TValue>> { public void Add(TKey key,TValue value) { Add(new KeyValuePair<TKey,TValue>(key,value)); } }
然后:
var list = new KeyValueList<string,"value2"} };
另一种方法是使用合成,但我的直觉是这是合理使用继承.我不能说为什么我在这种情况下很开心,但通常不会,请注意……