繁体   English   中英

如果FirstOrDefault返回null,则从FirstOrDefault中选择一个属性

[英]selecting a property from FirstOrDefault in case FirstOrDefault returns null

我想发表以下声明:

var block = blocksById.FirstOrDefault(X => X.Value == tracResult.ID).Key

我的问题是如果我有FirstOrDefault null值,如何更正确地处理它。 我只是不觉得if声明是可以在这里的唯一解决方案......

自从引入空条件运算符(?)以来,它就像:

var block = blocksById.FirstOrDefault(X => X.Value == tracResult.ID)?.Key;

请记住,在这种情况下,即使Value是一个intblock也将是Nullable<int>类型,因此可以为null

但是,如果要返回null,则要返回null ,可以使用null合并运算符(??)是这样的:

var block = blocksById.FirstOrDefault(X => X.Value == tracResult.ID)?.Key ?? 6;

不过,对于更复杂的Select语句,以下内容仍然有效......


前一段时间...

将它拆分为WhereSelect

var block = blocksById.Where(x => x.Value == tracResult.ID)
                      .Select(x => x.Key)
                      .FirstOrDefault();

这样,如果FirstOrDefault返回null您将不会获得NullRefferenceException。

另外你可以给它一个默认值,如下所示:

var block = blocksById.Where(x => x.Value == tracResult.ID)
                      .Select(x => x.Key)
                      .FirstOrDefault() ?? somedefaultvalue;

或者@Silvermind声明不可为空的可空类型( int的):

var block = blocksById.Where(x => x.Value == tracResult.ID)
                      .Select(x => (int?) x.Key)
                      .FirstOrDefault() ?? somedefaultvalue;

更新:有些人似乎怀疑这是一个有效的用例,并认为必须在程序中稍后进行null检查。

虽然在很多情况下都是如此,但并不总是必须如此,或者如果是这样的话,这种方式可能会更方便。

一些例子:

//one liner, null check delegated (not my favorite): 
return SomeCalculatedValue(collection.Where(condition).Select(selection).FirstOrDefault());

//or a mapping (shown with default value):
var result = collection.Where(condition)
                       .Select(c => 
                           { 
                                Foo = c.Foo,
                                Bar = c.Bar
                           }).FirstOrDefault()) ?? new { Foo = "New", Bar = "Empty"};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM