问题描述
这可能是一个简单的答案。
我正在制作这个 LINQ 表达式,其中我按“名称”对列表进行分组,然后创建一个 SymbolField 集合,其中将组键(名称)用作名称,并将值连接在一起作为第二个参数。
但问题更多,如何避免可能的空引用?
如果您查看图片,您会发现“可能”存在 group.key
为 null 的情况。
我只想选择非空的。如何根据我的代码执行此操作?
return result
.GroupBy(r => r.Name)
.Select(group =>
new SymbolField(group.Key,string.Join(string.Empty,group.Select(g => g.Symbol))));
解决方法
我认为这是针对 Linq-to-Objects(而不是 Linq-to-Entities),您看到的消息是 C# 8.0 #nullable
警告,因为 r.Name
的类型为 {{1 }} 而不是 String?
。
如果是这样,那么添加一个 String
步骤,然后在 .Where( r => r.Name != null )
步骤中添加一个 !
因为不幸的是,这是 C# 8.0 编译器的可空性分析不是的情况之一t 足够聪明,可以检测(还)。
.GroupBy