我安全地在列表中搜索这样的对象:
var someResult = myList.FirstOrDefault(x=>x.SomeValue == "SomethingHere");
如果没有对象符合我的条件,则 someResult
将为空。
但是如果我只有我想要的对象的索引,事情就不太好了。我似乎不得不这样:
try
{
var someResult = myList[4];
}
catch (ArgumentOutOfRangeException)
{
someResult = null;
}
我承认不得不写并不可怕。但在我看来,如果索引最终是伪造的,应该有一种方法可以让列表返回 null。
是否可以使用现有的 .net 方法 查找一(或两)行?
(我知道我可以很容易地编写一个扩展方法,但我想知道是否有内置的方法来做到这一点。)
最佳答案
我想你想要C.B.s suggestion ElementAtOrDefault
- 去投票吧。
我还有几点要补充...
关于您的 try/catch 解决方案:
I admit that is not terrible to have to write.
请不要为此使用异常(exception)。您的方法更冗长,异常很慢,因此您的性能会很差,并且异常应该只用于特殊情况。
通过使用 conditional operator 无需 LINQ 即可轻松编写此代码:
var someResult = myList.Count > 4 ? myList[4] : null;
关于c# - 是否有一种简洁的内置方法可以通过索引获取列表项而不会引发异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11422423/