ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

VB 如何判断数组为空

2021-02-21 14:01:00  阅读:188  来源: 互联网

标签:VB ByRef 为空 Long 数组 msg SafeArrayGetDim


方法一:Error方法

就是采用通用的错误捕获功能

On Error Goto 行号       '遇到错误,转到行号处处理

On Error Resume Next '忽略错误,继续执行

On Error Goto 0           '强制取消错误捕获功能

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)

安全数组的头两位就保存着维数信息

Option Explicit

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()的返回值,返回值值<=0,说明数组元素个数为0或者数组还没有初始化.

SafeArrayGetDim用来判断一个数组的维数,该函数在MSDN中定义为:

UINT SafeArrayGetDim(

  SAFEARRAY FAR* psa 

转换维VB中的语法格式为:

Public Declare Function SafeArrayGetDim Lib "oleaut32.dll" (ByRef saArray() As Any) As Long

如果数组已经初始化,则返回非0,否则返回0。

'API判断数组为空或没有初始化

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 = "arr1 " & IIf(SafeArrayGetDim(arr1) > 0, "数组不为空!", "数组为空!")

arr2 = Split("一、二、三、四、五、六", "、")

msg = msg & vbCrLf & "arr2 " & IIf(SafeArrayGetDim(arr2) > 0, "数组不为空!", "数组为空!")

msg = msg & vbCrLf & "arr3 " & IIf(SafeArrayGetDim(arr3) > 0, "数组不为空!", "数组为空!")

ReDim arr4(1 To 100)

msg = msg & vbCrLf & "arr4 " & IIf(SafeArrayGetDim(arr4) > 0, "数组不为空!", "数组为空!")

ReDim arr6(1 To 256, 1 To 65536)

msg = msg & vbCrLf & "arr5 " & IIf(SafeArrayGetDim(arr5) > 0, "数组不为空!", "数组为空!")

msg = msg & vbCrLf & "arr6 " & IIf(SafeArrayGetDim(arr6) > 0, "数组不为空!", "数组为空!")

MsgBox msg

End Sub

方法四:使用cstr(Join(list[, delimiter]))函数的返回值是否不等于""

将delimiter参数设置为""

例如:if (cstr(join(arr,""))) = "" then msgbox "arr 数组为空或者尚未初始化"

标签:VB,ByRef,为空,Long,数组,msg,SafeArrayGetDim
来源: https://www.cnblogs.com/rosesmall/p/14425647.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有