最新更新 sitemap 网站制作设计本站搜索
网页设计
国外网站 韩国网站 个人主页 手提袋设计 CSS 网页特效 平面设计 网站设计 Flash CMS技巧 服装网站 php教程 photoshop 画册 服务器选用 数据库 Office
虚拟主机 域名注册 云主机 网页设计 客服QQ:8208442
当前位置:首页 > 编程开发 > asp教程

ASP开发中数组全集多维数组和一维数组技巧

日期:09-17    来源:中国设计秀    作者:cnwebshow.com

asp数组是比较好用的装载大量数据的容器。4MB中国设计秀

1、定义数组4MB中国设计秀

有两种方式:DIM和REDIM。4MB中国设计秀

DIM定义的是固定个数、数据类型的数组;而REDIM则不同,它可以定义不同类型的数据,也可以定义个数并非固定的数据。比较下面几个例子。 都合法的例子:4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Dim myarray(5,2) 4MB中国设计秀
Redim myarray(5,2)4MB中国设计秀

4MB中国设计秀
前者错误而后者合法的例子:4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
n=104MB中国设计秀

Dim myarray(n) 4MB中国设计秀
Redim myarray(n,2)4MB中国设计秀

4MB中国设计秀
另外REDIM还可以定义未定类型的数组,如:4MB中国设计秀
 程序代码4MB中国设计秀
Redim myarray(10)4MB中国设计秀
 4MB中国设计秀

2、数组个数4MB中国设计秀

在以DIM或REDIM定义数组时指定的下标,表示的是访问该数组时所容许的最大下标,却不是该数组的个数。实际上,一维数组个数总是等于(最大下标+1),访问时是通过下标从0开始逐个访问的。4MB中国设计秀

比如:4MB中国设计秀
 程序代码4MB中国设计秀
Dim myarray(5) 4MB中国设计秀
定义的数组元素有6个,分别是:4MB中国设计秀

4MB中国设计秀
 引用内容4MB中国设计秀
myarray(0)、myarray(1)、myarray(2)、myarray(3)、myarray(4)、myarray(5)4MB中国设计秀

4MB中国设计秀
再如:4MB中国设计秀
 程序代码4MB中国设计秀
Redim thisarray(2,5)4MB中国设计秀
实际上定义了一个(2+1)*(5+1)=1 8的二维数组。4MB中国设计秀

既然如此,那么,可不可义定义一个只有一个元素的数组呢?答案是:不可以。4MB中国设计秀

如前所说,4MB中国设计秀
 程序代码4MB中国设计秀
Redim thisarray(1)4MB中国设计秀
定义的数组实际上有(1+1)个数组元素,但类似于: 4MB中国设计秀
 程序代码4MB中国设计秀
Redim thisarray(0)4MB中国设计秀
的语法,错误的。所以,不能定义一个只有一个数组元素的数组。 其实,以上说的只是其默认状况。其实,定义数组可以通过定义下标的起止从而达到定义数组的个数甚至下标的起止编号的。比如:4MB中国设计秀
 程序代码4MB中国设计秀
Redim thisarray(1980 to1990)4MB中国设计秀
就 定义了一个含有11个元素的数组,下标从1980到1990。 4MB中国设计秀

3、关于UBOUND函数4MB中国设计秀

UBOUND返回的是一维数组的最大下标,而不是元素个数。 比如:4MB中国设计秀
 程序代码4MB中国设计秀
Dim Myarray(5)4MB中国设计秀
,那么4MB中国设计秀
 程序代码4MB中国设计秀
UBOUND(Myarray)4MB中国设计秀
返回的值是5,而不是6。 UBOUND也可以应用于二维数组。应用于二维数组时,它返回的是第一个下标的最大值。4MB中国设计秀

比如:4MB中国设计秀
 程序代码4MB中国设计秀
Dim Myarray(6,3)4MB中国设计秀
, 那么4MB中国设计秀
 程序代码4MB中国设计秀
UBOUND(Myarray)4MB中国设计秀
返回的值是6,而不是7,更不是18(6*3=18)。4MB中国设计秀

若要返回第二个下标的最大值,则使用:4MB中国设计秀
 程序代码4MB中国设计秀
UBOUND(Myarray,2)4MB中国设计秀
4MB中国设计秀

与UBOUND相对应的是另外一个函数:LBOUND,它返回数组的最小下标。与UBOUND类似,LBOUND(Myarray,2)则返回数组MYARRAY的第二个下标的最小值。所以,准确地说,一维数组Myarray的元素个数为:4MB中国设计秀
 程序代码4MB中国设计秀
UBOUND(Myarray)-LBOUND(Myarray)+14MB中国设计秀
,而二维数组的元素个数则为:4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
(UBOUND(Myarray)-LBOUND(Myarray)+1)*(UBOUND(Myarray,2)-LBOUND(Myarray,2)+1)4MB中国设计秀
http://www.knowsky.com/4MB中国设计秀

多维数组依此类推。4MB中国设计秀

4、数组的定义4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Dim MyArray 4MB中国设计秀
MyArray = Array(1,5,123,12,98)4MB中国设计秀

4MB中国设计秀
可扩展数组4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Dim MyArray() 4MB中国设计秀
for i = 0 to 10 4MB中国设计秀
ReDim PReserve MyArray(i) 4MB中国设计秀
MyArray(i)=i 4MB中国设计秀
next4MB中国设计秀

4MB中国设计秀
将一个字符串分割并返回分割结果的数组4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Dim MyArray 4MB中国设计秀
MyArray = Split(tempcnt,chr(13)&chr(10)) 4MB中国设计秀
For I = Lbound(MyArray) to Ubound(MyArray) 4MB中国设计秀
Response.Write MyArray(I) & "<br>" 4MB中国设计秀
Next4MB中国设计秀

4MB中国设计秀
5、数组排序函数4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Function Sort(ary) 4MB中国设计秀
KeepChecking = TRUE 4MB中国设计秀
Do Until KeepChecking = FALSE 4MB中国设计秀
KeepChecking = FALSE 4MB中国设计秀
For I = 0 to UBound(ary) 4MB中国设计秀
If I = UBound(ary) Then Exit For 4MB中国设计秀
If ary(I) > ary(I+1) Then 4MB中国设计秀
FirstValue = ary(I) 4MB中国设计秀
SecondValue = ary(I+1) 4MB中国设计秀
ary(I) = SecondValue 4MB中国设计秀
ary(I+1) = FirstValue 4MB中国设计秀
KeepChecking = TRUE 4MB中国设计秀
End If 4MB中国设计秀
Next 4MB中国设计秀
Loop 4MB中国设计秀
Sort = ary 4MB中国设计秀
End Function4MB中国设计秀

4MB中国设计秀
数组排序函数应用例子4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Dim MyArray 4MB中国设计秀
MyArray = Array(1,5,123,12,98) 4MB中国设计秀
MyArray = Sort(MyArray) 4MB中国设计秀
For I = Lbound(MyArray) to Ubound(MyArray) 4MB中国设计秀
Response.Write MyArray(I) & "<br>" 4MB中国设计秀
Next4MB中国设计秀

4MB中国设计秀
6、在application和session中使用数组4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Application.Lock 4MB中国设计秀
Application("StoredArray") = MyArray 4MB中国设计秀
Application.Unlock 4MB中国设计秀

LocalArray = Application("StoredArray")4MB中国设计秀

4MB中国设计秀
覆盖Application中的数组4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Application.Lock 4MB中国设计秀
Application("StoredArray") = LocalArray 4MB中国设计秀
Application.Unlock4MB中国设计秀

4MB中国设计秀
Session使用方法与Application相同4MB中国设计秀

7、从数据库中把数据导入数组中4MB中国设计秀

这种方法被我经常用于代码的函数集成中。4MB中国设计秀

4MB中国设计秀
 程序代码4MB中国设计秀
Dim MyArray 4MB中国设计秀
取出全部记录 4MB中国设计秀
MyArray = RS.GetRows 4MB中国设计秀
取出前10项记录 4MB中国设计秀
MyArray = RS.GetRows(10) 4MB中国设计秀

For row = 0 To UBound(MyArray, 2) 4MB中国设计秀
For col = 0 To UBound(MyArray, 1) 4MB中国设计秀
Response.Write (col, row) & "<br>" 4MB中国设计秀
Next 4MB中国设计秀
Next4MB中国设计秀
 4MB中国设计秀

本文引用地址:/bc/article_46294.html
网站地图 | 关于我们 | 联系我们 | 网站建设 | 广告服务 | 版权声明 | 免责声明