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 2008-06-09 14:35  阳春三月  阅读(3205)  评论(0编辑  收藏  举报

导航