我有以下 Linq lambda 表达式:
private IEnumerable<SubjectSelectorSubjectGroup> GetSubjectList()
{
User user = db.Users.Find(WebSecurity.CurrentUserId);
return db.RequiredSubjects.Where(r => !r.Subject.Name.Contains("Home"))
.GroupBy(r => r.Subject)
.OrderByDescending(r => r.Count())
.Select(r => new SubjectSelectorSubjectGroup()
{
SubjectId = r.Key.SubjectId,
SubjectName = r.Key.Name,
IsInFavourites = HttpContext.Current.Request.IsAuthenticated &&
(user.Elective1 != null && user.Elective1.SubjectId == r.Key.SubjectId ||
user.Elective2 != null && user.Elective2.SubjectId == r.Key.SubjectId ||
user.Elective3 != null && user.Elective3.SubjectId == r.Key.SubjectId),
Occurrences = r.Count()
});
}
当用户未登录时user
,此函数中的变量为空。这应该不是问题,因为短路布尔评估应该处理这个问题。问题是,它没有!相反, aSystem.NullReferenceException
被抛出。
当用户为 nullHttpContext.Current.Request.IsAuthenticated
时返回 false。我通过注释掉引用user
变量的括号部分来检查这一点,然后表达式正确计算。
有谁知道为什么在这种情况下实际上不需要时Linq to Sql
尝试取消引用变量?user
有没有人可以解决这个问题?