微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 是DBNull与DBNull.Value.Equals()

我很好奇使用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)).

解决方法

我会选择dbnull.Value.Equals方式.

为什么?

Beacuse将检查类型是否相等.它必须查找左手类型并将其与右手类型匹配,它也必须查找.之后,它可以比较类型,最有可能通过检查参考相等性.

这比仅检查引用相等性(dbnull.Value.Equals所做的那样)效率低.由于只有一次dbnull.Value实例,因此该检查非常准确且非常快.

原文地址:https://www.jb51.cc/csharp/100580.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐