我很好奇使用if(some_value是DBNull)与if(DBNull.Value.Equals(some_value))的优缺点是什么.
我个人更喜欢if(some_value是DBNull),因为我发现它更具可读性.
我知道微软建议根据 https://msdn.microsoft.com/en-us/library/system.dbnull%28v=vs.110%29.aspx使用if(DBNull.Value.Equals(some_value)).
我个人更喜欢if(some_value是DBNull),因为我发现它更具可读性.
我知道微软建议根据 https://msdn.microsoft.com/en-us/library/system.dbnull%28v=vs.110%29.aspx使用if(DBNull.Value.Equals(some_value)).
解决方法
我会选择DBNull.Value.Equals方式.
为什么?
Beacuse将检查类型是否相等.它必须查找左手类型并将其与右手类型匹配,它也必须查找.之后,它可以比较类型,最有可能通过检查参考相等性.
这比仅检查引用相等性(DBNull.Value.Equals所做的那样)效率低.由于只有一次DBNull.Value实例,因此该检查非常准确且非常快.