如何判断数组是否已初始化,定义了维数

11 篇文章 0 订阅
3 篇文章 0 订阅
 如何判断数组是否已初始化,定义了维数 


最近用Split("",",")函数,遇到如何简明判断数组是否初始化问题,找到了一些方法,只有方法一最简单,记之。


方法一:使用cstr(Join(list[, delimiter]))函数的返回值
    将delimiter参数设置为""
    例如:  join(strArray,"") = ""    'arr 数组为空或者尚未初始化


方法二:Error方法
    就是采用通用的错误捕获功能
    Function IsNotEmpty(ByVal sArray As Variant) As Boolean '判断数组是否为空
        Dim i     As Long
        IsNotEmpty = True
        On Error GoTo lerr:
        i = UBound(b)
        Exit Function
    lerr:
        IsNotEmpty = False
    End Function


方法三:CopyMemory方法
    VB的数组都是安全数组,通过访问一个结构来确定数组内容保存位置,上标下标和维数
    
    安全数组的头两位就保存着维数信息
    Private Declare Function VarPtrArray Lib "msvbvm60.dll" Alias "VarPtr" (ByRef Ptr() As Any) As Long
    Private Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" _
             (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)


    Private Sub Form_Load()
    Dim MyArr() As Long
Dim pMyarr As Long
    Dim nDims As Integer
        '从数据指针得到SafeArray结构的指针
        CopyMemory pMyarr, ByVal VarPtrArray(MyArr), 4
        If pMyarr = 0 Then
            MsgBox "这个数组是空数组"
            '再从这个指针所指地址的头两个字节取出cDims
            CopyMemory nDims, ByVal pMyarr, 2
           MsgBox "这个数组有" & nDims & "维"
        End If
    End Sub


方法四:使用api函数safearraygetdim()的返回值,判断数组为空或没有初始化


使用api函数safearraygetdim()的返回值,返回值值<=0,说明数组元素个数为0或者数组还没有初始化.
SafeArrayGetDim用来判断一个数组的维数,该函数在MSDN中定义为:


Public Declare Function SafeArrayGetDim Lib "oleaut32.dll" (ByRef saArray() As Any) As Long
如果数组已经初始化,则返回非0,否则返回0。

    Sub diag()
Dim msg As String
Dim arr1() As String, arr2() As String, arr3() As Date, arr4() As Date, arr5() As Range, arr6() As Range
msg =  IIf(SafeArrayGetDim(arr1) > 0, "数组不为空!", "数组为空!")
arr2 = Split("一、二", "、")
msg =  IIf(SafeArrayGetDim(arr2) > 0, "数组不为空!", "数组为空!")
ReDim arr4(1 To 100)
msg = IIf(SafeArrayGetDim(arr4) > 0, "数组不为空!", "数组为空!")
ReDim arr6(1 To 256, 1 To 65536)
msg = IIf(SafeArrayGetDim(arr6) > 0, "数组不为空!", "数组为空!")
    End Sub

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值