Linq error: Sequence contains no elements

 
    程序报异常:Sequence contains no elements。首先想到 Oracle 数据库中用到的 Sequence 对象,查之未超限,.NextVal、.CurrVal 都正常。Google 之,异常是 IQuerable<T>.First() 方法报的,当查询的结果集为空时,调用 First() 方法将报此异常,换用 FirstOrDefault() 方法,则不报异常,问题解决。
 
    思考一:在 Google 中搜索时,一开始用的关键字是加双引号的 "Sequence contains no element",这是同事从电话里告知的异常信息,用这个关键字搜不到有价值的信息;当我在现场再现了这个异常后,直接把异常文本复制到 Google 中搜索,此时关键字是加双引号的 "Sequence contains no elements",结果一下子就定位到了问题的所在,而两次仅仅是关键字“element”和“elements”单复数的差异。
    这很出乎我的意料,按通常的思路,“element”应比“elements”搜到更多的结果,包含“elements”的网页应该是“element”的子集。难道 Google 有英语的语法分析功能?
 
    思考二:程序中调用 void 的方法时,经常需要知道方法是否成功执行,若不成功,需要知道不成功的原因(通常是异常消息)。比如要执行的方法叫 FooA(),FooA 的一种实现办法是在不成功时抛出异常,调用方捕捉到异常自然就知道 FooA 执行失败,也得到了失败的原因。但我经常用的方式是不抛出异常,而是用布尔返回值 true、false 表示成功与否,加一个 out string 参数携带失败时的消息。这样做的好处有二:一是避免了处理异常时要消耗很多的资源,二是在多次循环其前次处理失败要求能继续进行后续处理,且调用方没有异常处理代码时,避免了程序一遇到异常就跳出执行。看到 IQuerable<T>.First 和 FirstOrDefault 方法,我想也可以多写个 FooAOrDefault 方法,让调用方想处理异常时调用 FooA,不想处理异常或避免被异常影响执行时调用 FooAOrDefault 方法。

posted on   阳春三月  阅读(3449)  评论(0编辑  收藏  举报

编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架

导航

< 2008年6月 >
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 1 2 3 4 5
6 7 8 9 10 11 12

统计

点击右上角即可分享
微信分享提示