我有一个代码:
var status = ...
var StatusMapping = new Dictionary<AnotherStatus, IList<Status>>
{
{
AnotherStatus,
new List<Status>
{
Status1,
Status2
}
}
}
foreach (var keyValuePair in StatusMapping)
{
if (keyValuePair.Value.Contains(status))
{
return keyValuePair.Key;
}
}
throw Exception();
我是C#的新手,从Java切换到了C#。在Java中,可以像这样轻松完成:
return StatusMapping
.entrySet()
.stream()
.filter(e -> e.getValue().contains(status))
.map(Map.Entry::getKey)
.findFirst()
.orElseThrow(() -> new Exception());
有没有办法使用LINQ?
答案 0 :(得分:11)
首先,如果您定期执行此操作,则可能需要考虑其他数据结构。字典并不是真正用于频繁的“基于值的某些方面的查找”。
哦,在C#中更简单:)
var key = StatusMapping.First(x => x.Value.Contains(status)).Key;
First()
如果没有匹配项,将引发异常。
如果您想使用默认值代替,可以使用:
var key = StatusMapping.FirstOrDefault(x => x.Value.Contains(status)).Key;
这将导致key
是AnotherStatus
(或任何键类型)的默认值。
请注意,这只能像这样完全工作,因为KeyValuePair<,>
是一种值类型,因此默认值是非null且带有默认键。如果您有一系列 reference 类型,则需要类似以下内容:
var property = sequence.FirstOrDefault(whatever)?.Property;
...,其中?.
是空条件运算符。