加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

谨慎使用IsMissing函数

发布时间:2020-12-16 23:19:26 所属栏目:大数据 来源:网络整理
导读:在VB6中提供了一个很好用的函数叫IsMissing,可以用来判断用户是否对缺省参数赋值,比如有以下一个函数体: Public Property Get Item(Optional ByRef Index As Integer,Optional ByRef Name As String) As TDMAttachment Dim i As Long Dim lngIndex As Lon

在VB6中提供了一个很好用的函数叫IsMissing,可以用来判断用户是否对缺省参数赋值,比如有以下一个函数体:

此函数是一个父类的属性,可以根据用户输入的索引或者名称来返回一个子类。从代码上看似乎没有什么问题,但是,当用户使用Set objChild=Item("名称")来获得子类对象时,返回的结果是不正确的。为什么会这样呢?原来,在VB里,除了VARIANT类型外,其它数据类型都被赋了初始值,比如所有的Byt、Integer、Long、Double等数值型初始始为0,String的初始值为""(注意,""并不是vbNullString),Object的初始值为Nothing,而IsMissing函数在判断时,是无法区分参数变量的值是VB设定的初始值还是用户赋予的值,因此检测结果始终为True,从而导致ElseIf Not IsMissing(Name) Then这一条分支代码根本不会运行。那么,如何避免这种情况呢?

其实,只要把数据类型改为Variant就可以了,修改后的代码如下:

虽然为了提供代码的健壮性,我一般主张尽量少使用Variant类型,但合理使用它,往往会起到一些良好的效果,但前提必须是——合理使用。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读