在编程中,我们经常会遇到null检查的大量出现的情况。我说的是:
if (doc != null)
{
if (doc.Element != null)
{
... and so on
}
else
throw new Exception("Element cannot be null");
} else {
throw new Exception("document cannot be null");
}基本上,整个事情变成了一个不可读的噩梦,所以我想知道:是否有更简单的方法来描述我想要做的事情呢?(除了空检查之外,我还不时得到类似于string.IsNullOrEmpty的东西。)
接受了答案:--我接受了有此链接的答案,因为所描述的方法是创新的,也正是我想要的。谢了肖恩!
发布于 2009-01-09 20:00:53
如果要检查传递给部分公共API的参数,那么就应该在方法的一开始使用“卫士子句”,就像丹·莫内戈所写的。如果您使用IsNotNull和其他方法创建或重用一些助手类,比如Assert,那么代码将很容易阅读(也许您确实只需要其中的一个)。
您的代码如下所示:
Assert.IsNotNull(doc, "document");
Assert.IsNotNull(doc.Element", "Element");
//... and so on如果您要检查传递给您的一个私有方法的参数,那么您不应该有这样的检查,而应该添加一个契约(在方法文档中,或者如果您正在使用某些工具),并且总是期望使用正确的参数来调用该方法。
https://stackoverflow.com/questions/429112
复制相似问题