<% Class HashMap dim arr() dim arr_len '构造函数 private Sub Class_Initialize '其中 arr(0,n)为key,arr(1,n)为value arr_len = 0 redim arr(1,arr_len) End Sub '======================== '*put方法 往MAP中插入键值对,如果Key存在则覆盖 '@k 键值key '@v key对应的value值 '======================== public Sub put(k,v) dim is_update is_update = false arr_len = ubound(arr,2) for i=0 to arr_len-1 if k=arr(0,i) then arr(1,i) = v is_update = true exit for end if next if not is_update then arr_len = arr_len +1 redim preserve arr(1,arr_len) arr(0,arr_len-1) = k arr(1,arr_len-1) = v end if End Sub '======================== '*getv方法 通过key值获取对应的value '@k 键值key '======================== public Function getv(k) dim v for i=0 to arr_len if k=arr(0,i) then v = arr(1,i) exit for end if next getv = v End Function '======================== '*keys方法 获取Map中所有的KEY,以数组形式返回 '======================== public Function keys() dim v() Redim v(arr_len) for i=0 to arr_len-1 v(i) = arr(0,i) next keys = v End Function '======================== '*values方法 获取Map中所有的Value,以数组形式返回 '======================== public Function values() dim v() Redim v(arr_len) for i=0 to arr_len-1 v(i) = arr(1,i) next values = v End Function '======================== '*remove方法 从MAP中移除指定key的键值对 '@k 键值key '======================== public Sub remove(k) arr_len = ubound(arr,2) for i=0 to arr_len if k=arr(0,i) then v = arr(1,i) for k = i to arr_len-1 arr(0,k) = arr(0,k+1) arr(1,k) = arr(1,k+1) next arr_len = arr_len - 1 redim preserve arr(1,arr_len) exit for end if next End Sub '======================== '*putAll 将源HashMap的所有值添加到当前对象中,如果存在重复key值将覆盖原有值 '@map 源HashMap '======================== public Function putAll(map) if typeName(map)<>"HashMap" then response.Write "putAll只能存放HashMap" else for i=0 to map.length-1 put map.keys()(i),map.values()(i) next End If End Function '======================== '*length属性 Map中的键值对数 '======================== public property get length() length = arr_len End property '======================== '*removeAll方法 移除MAP中所有值 '======================== public Sub removeAll() arr_len = 0 redim arr(1,1) End Sub End Class %>
<% '***************ArrayList属性*************** 'ArrayList.Length:数组长度 '***************ArrayList方法*************** '---数组添加: 'ArrayList.Add(v):在ArrayList尾部添加一个元素 'ArrayList.AddArray(arr):在ArrayList尾部附加一个数组 'ArrayList.Insert(index,v):在ArrayList的index处插入一个值,原先的index和之后的值都往后移 'ArrayList.InsertArray(index,arr):在ArrayList的index处插入一个数组,原先的index和之后的值都往后移 '---数组更新: 'ArrayList.Update(index,v):更新索引为index处的值 '---数组删除: 'ArrayList.Remove(v):从ArrayList中删除第一个匹配项,注意是第一个,将会得到一新的数组 'ArrayList.RemoveAt(index):移除ArrayList的指定索引处的元素,将会得到一新的数组 'ArrayList.Splice(m,n):从一个数组中移除从索引m到索引n的一段元素,并返回这段移除的数组 'ArrayList.Clear()清空数组,数组将变为空,长度Length=0 '---数组查找: 'ArrayList.IndexOf(v):查找,返回ArrayList第一个匹配项的索引。没找到返回-1。 'ArrayList.LastIndexOf(v):返回ArrayList的最后一个匹配项的索引。没找到返回-1。 '---返回数组中的值: 'ArrayList.GetValue(index)取得ArrayList某个索引的值 'ArrayList.Slice(m,n)返回ArrayList从m到n的一段数组 'ArrayList.GetArray()返回整个Array数组 '---数组其他操作: 'ArrayList.Reverse()将整个 ArrayList 中元素的顺序反转 'ArrayList.Implode(separator)返回字符串值,元素由指定的分隔符分隔开来 '******************************/ Class ArrayList Private arrList'//内部数组 Private arrLength'//记录数组的长度 Private Sub Class_Initialize() arrList=Array() arrLength=0 End Sub Private Sub Class_Terminate() Erase arrList End Sub '//数组长度,只读 Public Property Get Length Length=arrLength End Property '//取得某个索引的值 Public Function GetValue(index) On Error Resume Next GetValue=arrList(index) If Err Then showErr "ArrayList.GetValue()"&Err.Description:Err.Clear:Exit Function End Function '//返回整个Array数组 Public Function GetArray() GetArray=arrList End Function '//添加元素,将值添加到ArrayList的结尾处 Public Sub Add(v) ReDim Preserve arrList(arrLength) arrList(arrLength)=v arrLength=arrLength+1 End Sub '//将数组添加到ArrayList的结尾处 Public Sub AddArray(arr) If Not IsArray(arr) Then showErr "参数不是数组(arr):ArrayList.AddArray()":Exit Sub Dim I,L,J On Error Resume Next If arrLength = 0 Then '//如果ArrayList为空则直接附值 arrList=arr arrLength=arrLength+UBound(arr)+1 Else L=arrLength+UBound(arr)'//新的数组长度 J=0 ReDim Preserve arrList(L) For I = arrLength To L arrList(I)=arr(J) J=J+1 Next arrLength=arrLength+UBound(arr)+1 End If If Err Then showErr "ArrayList.AddArray()"&Err.Description:Err.Clear:Exit Sub End Sub '//将元素插入ArrayList的指定index索引处,原有的arrList(index)及后面的元素都往后排 Public Sub Insert(index,v) Dim I,v2 If index<arrLength And index>=0 Then ReDim Preserve arrList(arrLength) arrLength=arrLength+1 For I = index To arrLength - 1 v2=arrList(I)'//交换值 arrList(I)=v v=v2 Next Else showErr "下标越界:ArrayList.Insert()" End If End Sub '//将一组数组插入到指定的index处 Public Sub InsertArray(index,arr) If index = "" Or Not IsNumeric(index) Then showErr "非法的参数:ArrayList.InsertArray()":Exit Sub End If If index < 0 Or index > arrLength-1 Then showErr "下标越界:ArrayList.InsertArray()":Exit Sub End If If Not IsArray(arr) Then showErr "参数不是数组:ArrayList.InsertArray()":Exit Sub Dim I,L1,L2,J:J=0 On Error Resume Next L1=UBound(arr) L2=arrLength+L1 ReDim Preserve arrList(L2) For I = arrLength -1 To index Step -1 arrList(I+L1+1)=arrList(I)'//把index之后的值往后移 Next For I = index To index+L1 arrList(I)=arr(J) J=J+1 Next If Err Then showErr "ArrayList.InsertArray()"&Err.Description:Err.Clear:Exit Sub arrLength=arrLength+L1+1'//新的数组长度 End Sub '//更新数组中索引为index的对应值 '//by xilou 39949376 Public Sub Update(index,v) If index = "" Or Not IsNumeric(index) Then showErr "非法的参数(index):ArrayList.Update()":Exit Sub End If If index < 0 Or index > arrLength-1 Then showErr "下标越界(index):ArrayList.Update()":Exit Sub End If arrList(index)=v End Sub '//从ArrayList中删除第一个匹配项,注意是第一个,将会得到一新的数组 Public Sub Remove(v) Dim I,index index = -1 '//第一个匹配的索引 For I = 0 To arrLength - 1 If arrList(I)=v Then index = I : Exit For Next If index <> -1 Then For I = index To arrLength - 2 arrList(I) = arrList(I+1)'//值向前填充 Next ReDim Preserve arrList(arrLength-1)'//收缩数组 arrLength = arrLength - 1 End If End Sub '//移除ArrayList的指定索引处的元素,将会得到一新的数组 Public Sub RemoveAt(index) If index = "" Or Not IsNumeric(index) Then showErr "非法的参数(index):ArrayList.RemoveAt()":Exit Sub End If If index < 0 Or index > arrLength-1 Then showErr "下标越界(index):ArrayList.RemoveAt()":Exit Sub End If If index > 0 Then For I = index To arrLength - 2 arrList(I) = arrList(I+1)'//值向前填充 Next ReDim Preserve arrList(arrLength-1)'//收缩数组 arrLength = arrLength - 1 End If End Sub '//从一个数组中移除从索引m到索引n的一段元素,并返回这段移除的数组 Public Function Splice(m,n) If m = "" Or n = "" Or Not IsNumeric(m) Or Not IsNumeric(n) Then showErr "非法的参数(m,n):ArrayList.Splice()":Exit Function End If If m < 0 Or m > arrLength-1 Or n < 0 Or n > arrLength-1 Then showErr "下标越界(m,n):ArrayList.Splice()":Exit Function End If Dim newArr,x,L,I,J newArr=Array() If m > n Then x=m:m=n:n=x '//交换数值 L=n-m ReDim Preserve newArr(L) For I = m To n newArr(J)=arrList(I)'要移除的元素 J=J+1 Next '//把n后面的元素的值移前 For I = (n+1) To arrLength -1 arrList(I-L-1)=arrList(I) Next arrLength=arrLength-L-1 ReDim Preserve arrList(arrLength) Splice=newArr End Function '//清空数组,数组将变为空,长度Length=0 Public Sub Clear() Erase arrList arrLength=0 End Sub '//将整个 ArrayList 中元素的顺序反转 Public Sub Reverse() Dim L,I,J,v J=arrLength-1 If arrLength > 0 Then L=Int(arrLength/2) For I = 0 To L-1 v=arrList(I) arrList(I)=arrList(J) arrList(J)=v J=J-1 Next End If End Sub '//返回字符串值,其中包含了连接到一起的数组的所有元素,元素由指定的分隔符分隔开来 Public Function Implode(separator) Implode=Join(arrList,separator) End Function '//返回ArrayList从m到n的一段数组 Public Function Slice(m,n) If m = "" Or n = "" Or Not IsNumeric(m) Or Not IsNumeric(n) Then showErr "非法的参数:ArrayList.Slice()":Exit Function End If If m < 0 Or m > arrLength-1 Or n < 0 Or n > arrLength-1 Then showErr "下标越界:ArrayList.Slice()":Exit Function End If Dim I,J,newArr() J=0 If m<=n Then ReDim Preserve newArr(n-m) For I = m To n newArr(J)=arrList(I) J=J+1 Next Else ReDim Preserve newArr(m-n) For I = n To m newArr(J)=arrList(I) J=J+1 Next End If Slice=newArr Erase newArr End Function '//查找,返回ArrayList第一个匹配项的从零开始的索引。没找到返回-1。 '//by xilou 39949376 Public Function IndexOf(v) Dim I For I = 0 To arrLength - 1 If arrList(I)=v Then IndexOf=I:Exit Function Next IndexOf=-1 End Function '//返回ArrayList的最后一个匹配项的从零开始的索引。没找到返回-1。 Public Function LastIndexOf(v) Dim I If arrLength=0 Then LastIndexOf=-1:Exit Function Else For I = (arrLength-1) To 0 Step -1 If arrList(I)=v Then LastIndexOf=I:Exit Function Next End If LastIndexOf=-1 End Function '//显示错误 Private Sub showErr(errInfo) Response.Write "<div id=""ERRORINFO"" style=""font-size:12px;color:#990000;font-family:""新宋体"", Arial"">" Response.Write errInfo Response.Write "</div>" Response.End() End Sub End Class %>