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实例,因此该检查非常准确且非常快.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...