如何在相应的linq中将foreach语句转换为可能的空值处理:
foreach (var val in userData.ManagedUsers.Values)
{
if (val.UserId == userId)
{
foreach (var role in val.Roles)
{
switch (role.ToLower())
{
case "underwriter1":
return "1";
case "underwriter2":
return "2";
case "underwriter3":
return "3";
}
}
}
}
答案 0 :(得分:4)
你可以用这个:
string result = userData.ManagedUsers.Values
.Where(u => u.UserId == userId)
.SelectMany(u => u.Roles)
.Select(r => {
if(String.Equals(r, "underwriter1", StringComparison.InvariantCultureIgnoreCase))
return "1";
else if(String.Equals(r, "underwriter2", StringComparison.InvariantCultureIgnoreCase))
return "2";
else if(String.Equals(r, "underwriter3", StringComparison.InvariantCultureIgnoreCase))
return "3";
else return null;
}).First(r => r != null);
我在这里不使用switch
,因为您需要使用ToLower
来区分不区分大小写。那时你没有通过turkey test。因此,我String.Equals
使用InvariantCultureIgnoreCase
,效率更高,处理Role
为null
的情况。
顺便说一句,如果我理解你的逻辑,这似乎会更好:
string result = userData.ManagedUsers.Values
.Where(u => u.UserId == userId)
.SelectMany(u => u.Roles)
.Select(r => r != null && r.StartsWith("underwriter") ? r.Substring("underwriter".Length) : null)
.First();