我在线上遇到了一个空引用异常:
dr["IsSandpit"] = p.MineralName.Equals("Sand");
当然修复是:
dr["IsSandpit"] = p.MineralName!=null && p.MineralName.Equals("Sand");
但是我想知道是否可以配置一个可空类型,Equals方法而不是抛出空引用异常只会返回强类型变量的false
?或者某种方法NotNullAndEquals
?
数据库中的空格意味着类似于"未填充"或空的"空"肯定不等于" Sand"。 (也许这是重复但我没有找到正确的问题)
答案 0 :(得分:5)
您可以在两个操作数上调用静态Equals
方法:
var isEqual = string.Equals("Sand", p.MineralName); // return false for null.
这将消除访问可能为空的引用的需要。 或者,如果值为null,则可以使用null传播运算符来避免操作:
var isEqual = p.MineralName?.Equals("Sand"); // return null for null.
这些是更好的方法,IMO,而不是使用扩展方法来破解理论上可以在空引用上调用的方法,因为这种方法会导致您是否可以安全地调用方法而不检查null。想象一下这段代码:
if (!p.MineralName.Equals("Sand"))
{
return p.MineralName.ToUpper(); // throws NullReferencException!
}
答案 1 :(得分:0)
表达式
null
如果p.MineralName
为空,将评估为p.MineralName?.Equals("Sand") ?? false
。然后,您可以将其合并为false,如下所示:
sendData(&ConnectSocket, "Content-Type: text/plain");
答案 2 :(得分:-1)
作为一个选项,您可以使用自行创建的 NotNullAndEquals 扩展方法:
public static class Utilities {
public static bool NotNullAndEquals(this string value, string expected) {
return value != null && value.Equals(expected);
}
}