请问如下UBound(array)返回的是5还是4呢? 在VBA中!

array("A","B","C","D","E")
请问UBound(array)返回的是5还是4呢? 在VBA中!

有只小跳蛙
浏览 253回答 2
2回答

慕容708150

返回4,因为默认下标是从0开始的。相当于A(0 to 4)UBound语法如下:返回一个 Long 型数据,其值为指定的数组维可用的最大下标。UBound(arrayname[, dimension])arrayname必需的。数组变量的名称,遵循标准变量命名约定。dimension可选的;Variant (Long)。指定返回哪一维的上界。1 表示第一维,2表示第二维,如此等等。如果省略 dimension,就认为是 1。对具有下述维数的数组而言,UBound 的返回值见下表:Dim A(1 To 100, 0 To 3, -3 To 4)UBound(A, 1) = 100UBound(A, 2) = 3UBound(A, 3) = 4

慕婉清6462132

如果没指明下标起始值,下标默认是从0开始的所以问题中返回的会是4如果VBA模块中用了这句Option Base 1则默认下标起始是1则问题中返回的会是5
打开App,查看更多内容
随时随地看视频慕课网APP