您好,今日西西来为大家解答以上的问题。数组赋值 vba,vb数组赋值相信很多小伙伴还不知道,现在让我们一起来看看吧!
1、数组必须先定义(声明),然后才能赋值。
2、下面全面讲解数组的相关知识: 数组的概念1.引例 求100个学生的平均成绩及超过平均成绩的人数。
3、 如果用一般变量来表示成绩,需要用100个变量,如:markmary2、……mark100。
4、若用数组,可以只用一个来表示mark(1 To 100)。
5、2.基本概念 数组:是同类型变量的一个有序的集合。
6、 如:A(1To 100),表示一个包含100个数组元素的名为A的数组。
7、 数组元素: 即数组中的变量。
8、用下标表示数组中的各个元素。
9、 表示方法:数组名(P1,P2,……) 其中PP2表示元素在数组中的排列位置,称为“下标”。
10、 如:A(3,2)代表二维数组A中第3行第2列上的那个元素。
11、 数组维数: 由数组元素中下标的个数决定,一个下标表示一维数组,二个下标表示二维数组。
12、 VB中有一维数组、二维数组、……最多60维数组。
13、 下标: 下标表示顺序号,每个数组有一个唯一的顺序号,下标不能超过数组声明时的上、下界范围。
14、下标可以是整型的常数、变量、表达式,甚至又是一个数组元素。
15、 下标的取值范围是:下界 To 上界 ,缺省下界时,系统默认取0。
16、3.数组声明 数组必须先声明后使用。
17、声明数组就是让系统在内存中分配一个连续的区域,用来存储数组元素。
18、 声明内容:数组名、类型、维数、数组大小。
19、 一般情况下,数组中各元素类型必须相同,但若数组为Variant时,可包含不同类型的数据。
20、 静态数组:声明时确定了大小的数组。
21、 动态数组: 声明时没有给定数组大小(省略了括号中的下标),使用时需要用ReDim语句重新指出其大小。
22、 静态数组及声明1. 一维数组 静态一维数组的声明形式: Dim 数组名(下标) [As 类型]说明:(1)下标必须为常数,不可以为表达式或变量; (2)下标下界最小为-32768,最大上界为32767;省略下界,其默认值为为0,一维数组的大小为:上界-下界+1 (3) 如果省略类型,则为变体型例: (1) Dim A(10) As Integer 声明了A是数组名、整型、一维数组、有11个元素,下标的范围是0~10。
23、 (2) Dim B(-3 To 5) As String*3 声明了B是数组名、字符串型、一维数组、有9个元素,下标的范围是-3~5,每个元素最多存放3个字符。
24、2.多维数组 静态多维数组的声明形式: Dim 数组名(下标1[,下标2…]) [As 类型] 说明: (1)下标个数决定数组的维数,最多60维。
25、 (2)每一维的大小=上界-下界+1;数组的大小=每一维大小的乘积。
26、 例:Dim C(-1To 5, 4) As Long 声明了C是数组名、长整型、二维数组、第一维下标范围为-1~5,第二维下标的范围是0~4,占据7x 5个长整型变量的空间。
27、3.注意事项 (1)在有些语言中,下界一般从1开始,为了便于使用,在VB的窗体层或标准模块层用Option Base n 语句可重新设定数组的下界,如Option Base 1。
28、 (2) 在数组声明中的下标关系到每一维的大小,是数组说明符,而在程序其他地方出现的下标为数组元素,两者写法相同,但意义不同。
29、 (3) 在数组声明时的下标只能是常数,而在其他地方出现的数组元素的下标可以是变量。
30、动态数组及声明1. 动态数组的建立与声明 建立动态数组的方法是:利用Dim、Private、Public语句声明括号内为空的数组,然后在过程中用ReDim语句指明该数组的大小。
31、语法是: ReDim 数组名(下标1[,下标2…]) [As 类型] 其中下标可以是常量,也可以是有了确定值的变量,类型可以省略,若不省略,必须与Dim中的声明语句保持一致。
32、 例: Dim D() As Single Sub Form_Load() …… ReDim D(4,6) …… End Sub2.注意事项 (1)在动态数组ReDim语句中的下标可以是常量,也可以是有了确定值的变量; (2)在过程中可以多次使用ReDim来改变数组的大小,也可改变数组的维数。
33、 (3)每次使用ReDim语句都会使原来数组中的值丢失,可以在ReDim语句后加Preserve参数来保留数组中的数据,但使用Preserve只能改变最后一维的大小,前面几维大小不能改变。
34、 使用动态数组的优点是根据用户需要,有效地利用存储空间,它是在程序执行到ReDim语句时才分配存储单元,而静态数组是在程序编译时分配存储单元。
本文就为大家分享到这里,希望小伙伴们会喜欢。