zoukankan      html  css  js  c++  java
  • VBScript:Empty与Null

    作为弱类型语言(loosely typed language),Variant是VBScript中唯一的数据类型,我们通过Variant的“子类型”来管理变量。记录一下两个比较特殊的子类型:Empty和Null。

    与其他子类型的区别

    当变量的子类型为Empty或Null时,它的值也就是名为Empty或Null的特殊值,这跟其他的子类型有些不同,其他的子类型只是说明变量中值得类型,而不是值本身。

    Empty子类型

    1. Empty等价于“未初始化”,当一个Variant变量被声明后,在往其中放入任何值之前,它就是空的,其子类型是Empty。

       1:  Dim varTest
       2:  MsgBox TypeName(varTest)
     

    2. 一旦给Variant变量赋值,它就不再为空。

    3. 如何将变量变成空的:

       1:  varTest = Empty

    4. 如何检查变量是否为空:

    方法一:

       1:  If varTest = Empty Then
       2:      MsgBox "The variable is empty."
       3:  End If

    方法二:

       1:  If IsEmpty(varTest) Then
       2:      MsgBox "The variable is empty."
       3:  End If

    5. Empty与空字符串比较:

       1:  Dim varTest
       2:  MsgBox varTest
       3:  MsgBox TypeName(varTest)
       4:  varTest = ""
       5:  MsgBox varTest
       6:  MsgBox TypeName(varTest)
    Empty子类型和空字符串从值来看都是空的,但他们的区别是:Empty子类型表示未被初始化,而空字符串已经被初始化为String子类型但被赋值为空。

    Null子类型

    1. Null表示变量中没有合适的值,只有明确地将Null放到变量中,变量才会是Null子类型。Null是个特殊的值,常见于数据库表格中。"null"这个概念反映的不仅仅是缺少值,也意味着当前值是未知的。

    2. 将Null值赋给变量:

       1:  varTest = Null

    3. 如何检查变量是否为Null:

       1:  If IsNull(varTest) Then
       2:      MsgBox "The variable has a Null value."
       3:  End If

    4. 通常从数据库或某些函数获取数据时,要注意Null值。因为Null表示非法的数据,如果您将Null传递给不兼容Null的函数或是用Null做数学计算,那它就会给您带来麻烦。

    以下代码会出错是因为将Null作为了CLng函数的参数:

       1:  Dim varTest
       2:  varTest = Null
       3:  varTest = CLng(varTest)

    此例子会在第三行出错,提示"Invalid Use of Null"。

    5. 将无效数据(Null)与有效数据混在一起时,您最终得到的永远是无效数据。

       1:  Dim varTest
       2:  Dim lngTest
       3:  varTest = Null
       4:  lngTest = 2 + varTest
       5:  MsgBox TypeName(lngTest)

    此例子结果为Null。

  • 相关阅读:
    spring boot Mybatis 拦截器,实现拼接sql和修改
    spring security 5.x去除默认前缀
    Umengday08-hive数据仓库建设
    Umengday07-flume、kafka与hdfs日志流转
    Umengday01-nginx模块(环境平台搭建)
    Umeng项目day04
    Java代码~~汽车租赁系统
    java基础知识(一)
    自动化测试知识点杂记,后续再进行整理
    博客第一天
  • 原文地址:https://www.cnblogs.com/ITGirlXiaoXiao/p/3127268.html
Copyright © 2011-2022 走看看