數(shù)組的定義與聲明_第1頁
數(shù)組的定義與聲明_第2頁
數(shù)組的定義與聲明_第3頁
數(shù)組的定義與聲明_第4頁
數(shù)組的定義與聲明_第5頁
已閱讀5頁,還剩3頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、數(shù)組的定義與聲明數(shù)組的定義與聲明 數(shù)組的定義語法如下:Dim 數(shù)組名( 下標(biāo)下界 To 下標(biāo)上界 ) As 數(shù)據(jù)類型例如(假設(shè)在當(dāng)前模塊中 數(shù)組的缺省下界為0): Dim A(10) As Integer表示數(shù)組名為A,此數(shù)組下標(biāo)下界為缺省值0,下標(biāo)上界為10,有11個(gè)Integer類型的元素,從A(0)、A(1)到A(10)。 Dim B(1 To 20) As Integer表示數(shù)組名為B,此數(shù)組下標(biāo)下界為1,下標(biāo)上界為20,有20個(gè)Integer類型的元素,從B(1)到B(20)。Dim DayArray(50)表示DayArray 是一個(gè)有 51 個(gè)索引(從 0 到 50)元素的 Va

2、riant 數(shù)組。Dim Matrix(3, 4) As Integer表示Matrix 是一個(gè)二維 Integer 數(shù)組。Dim MyMatrix(1 To 5, 4 To 9, 3 To 5) As Double表示MyMatrix 是一個(gè)顯式指定了上下界的三維 double 數(shù)組。Dim BirthDay(1 To 10) As Date表示BirthDay 是一個(gè)索引從 1 到 10 的 Date型 數(shù)組。2Option Base 語句 Option Base 語句在模塊級別中使用,用來聲明數(shù)組下標(biāo)的缺省下界。Option Base 語句的語法如下:Option Base 0 | 1說

3、明:缺省狀態(tài)下數(shù)組下界為 0,此時(shí)無需使用 Option Base 語句。如果使用該語句規(guī)定數(shù)組下界1,則必須在模塊的數(shù)組聲明之前使用Option Base 語句。注意:(1)Dim、Private、Public、ReDim 以及 Static 語句中的 To 子句提供了一種更靈活的方式來控制數(shù)組的下標(biāo)。不過,如果沒有使用 To 子句顯式地指定下界,則可以使用 Option Base 將缺省下界設(shè)為 1。使用 Array 函數(shù)創(chuàng)建的數(shù)組的下界也受 Option Base 語句指定的下界的決定, 除非 Array 是由類型庫(例如 VBA.Array )名稱限定,如果是由類型庫名稱限定,則 使用

4、Array 函數(shù)創(chuàng)建的數(shù)組的下界不受 Option Base 的影響。 (1) Option Base 語句只影響位于包含該語句的模塊中的數(shù)組下界。 關(guān)于數(shù)組聲明的幾點(diǎn)說明:數(shù)組名命名規(guī)則和變量名的相同。數(shù)組名后是用圓括弧括起來的,不能用方括弧,不同于C語言。下標(biāo)的下界必須不能大于其上界??梢杂米兞棵虺?shù)名(以及實(shí)數(shù))作下標(biāo)的邊界。當(dāng)下標(biāo)的邊界是常數(shù)名時(shí),數(shù)組的大小固定,當(dāng)下標(biāo)的邊界是變量名時(shí),數(shù)組的大小可作動態(tài)定義,即數(shù)組的大小取決于程序運(yùn)行過程中變量的值。因此,VB 中數(shù)組又可以分為兩種數(shù)組:靜態(tài)數(shù)組、動態(tài)數(shù)組。3靜態(tài)數(shù)組 靜態(tài)數(shù)組是指數(shù)組元素的個(gè)數(shù)是固定不變的,即它們占用的內(nèi)存空間大小

5、是固定不變的。根據(jù)固定大小數(shù)組的維數(shù)不同,可以將它分為一維數(shù)組和多維數(shù)組。聲明多維數(shù)組的語法格式為:Dim 數(shù)組名(下標(biāo)邊界列表) As 數(shù)據(jù)類型下標(biāo)邊界的定義形式:下標(biāo)下界 To下標(biāo)上界下標(biāo)邊界列表指用逗號分開的數(shù)組各維的下標(biāo)邊界,即下標(biāo)下界 To下標(biāo)上界,下標(biāo)下界 To下標(biāo)上界,下標(biāo)下界 To下標(biāo)上界(第一維) (第二維) (第n維)當(dāng)n=1時(shí),數(shù)組稱作一維數(shù)組;當(dāng)n=2時(shí),數(shù)組稱作二維數(shù)組;依次類推,當(dāng)n=m時(shí),數(shù)組稱作m維數(shù)組。下面舉例介紹一維數(shù)組的使用。聲明一個(gè)長度為51的字符串?dāng)?shù)組FriendsNameDim FriendsName(50) As String聲明一個(gè)長度為11的全

6、局整型數(shù)組ClassPublic Class(10) As Integer一維數(shù)組中的元素個(gè)數(shù)為(上界-下界+1)。為數(shù)組賦初值可以采用循環(huán)語句,如:Dim I As IntegerFor I = 0 To 11 循環(huán)語句的使用程序流程的控制C(I) = INext I如果不顯式指定下標(biāo)下界,則數(shù)組的下標(biāo)下界由 Option Base 語句控制。如果沒有 Option Base 語句則下界為默認(rèn)為 0。數(shù)組的維數(shù)并不限于,在VB中,可以擴(kuò)大至于60,在實(shí)際應(yīng)用上對三維以上的數(shù)組的應(yīng)用是不多的。定義一個(gè)多維數(shù)組時(shí)只需一條Dim語句指定數(shù)組的所有下標(biāo)邊界即可,使用多維數(shù)組的可以很方便的表示一些有意

7、義的統(tǒng)計(jì)數(shù)據(jù)。例如:Dim Profit(16,10,12) As Currency這個(gè)Profit數(shù)組可用來表示以店名、部門及月份為參數(shù)的某百貨公司的利潤。如:Profit(2,8,11)代表了第二分店的第八部門在11月份的利潤。4動態(tài)數(shù)組 有時(shí)在數(shù)組開始使用前,不能知道需要多大的數(shù)組才能滿足實(shí)際需要。當(dāng)然可以把數(shù)組的大小定義到足夠大來滿足任意的實(shí)際應(yīng)用需要,這種方法效率很低(大量浪費(fèi)內(nèi)存空間)。如果使用動態(tài)數(shù)組,就可以在程序運(yùn)行時(shí)根據(jù)實(shí)際需要,精確定義數(shù)組的大小。在聲明數(shù)組時(shí),不給出維數(shù)列表就是將數(shù)組聲明為動態(tài)數(shù)組。例如:Dim MyArry() As Integer在使用動態(tài)數(shù)組前,必須

8、使用ReDim語句把它重新定義。如前面聲明的數(shù)組MyArry,可以用以下語句將它定義為一個(gè)動態(tài)二維數(shù)組。ReDim MyArry(10,10)還可以通過重復(fù)執(zhí)行ReDim語句,多次定義動態(tài)數(shù)組。使用ReDim最多能定義數(shù)組的維數(shù)是60。ReDim語句可以改變數(shù)組每維的元素個(gè)數(shù),但不能改變維數(shù)。下面是對ReDim語句的一個(gè)標(biāo)準(zhǔn)應(yīng)用舉例。Dim MyArry() As Single 聲明動態(tài)數(shù)組ReDim MyArry(30,20,10) 重新定義數(shù)組ReDim MyArry(50,23,21) 再次重新定義數(shù)組ReDim的語法與Dim的相同,此外,它還有選擇項(xiàng)Preserve關(guān)鍵詞:ReDim

9、Preserve 數(shù)組名 ( 下標(biāo)下界 To下標(biāo)上界) As 數(shù)據(jù)類型例如:ReDim MyArry(50,23,21)ReDim Preserve MyArry(50,23,50)注意:使用ReDim 時(shí),重新定義數(shù)組會使所有數(shù)組元素的值消失,而使用Preserve可以保留數(shù)據(jù)。但是用Preserve只能在改變數(shù)組的最后一維的大小時(shí),保留數(shù)組的數(shù)據(jù)。對于一維數(shù)組來說,所有數(shù)據(jù)都會保留,而對于多維數(shù)組:只能改變最后一維的大小,才能保留全部數(shù)組數(shù)據(jù),否則出錯(cuò)。 5LBound 函數(shù)和UBound 函數(shù) LBound 函數(shù)和Ubound函數(shù)都是返回一個(gè) Long 型數(shù)據(jù),前者得到的值為指定數(shù)組維可

10、用的最小下標(biāo),而后者得到的是最大下標(biāo)。它們的語法為:LBound(數(shù)組名, 指定的維數(shù))UBound(數(shù)組名, 指定的維數(shù))其中數(shù)組名是必選的。指定的維數(shù)是可選的,表明指定返回哪一維的下界。1 表示第一維,2 表示第二維,如此類推。如果省略指定的維數(shù),就默認(rèn)為是 1。關(guān)于如何使用LBound 函數(shù)與 UBound 函數(shù)可參見下例:Dim A(1 to 100,3,-3 to 4) As Integer 定義一三維數(shù)組,假定沒有使用Option Base 語句改變數(shù)組下界的默認(rèn)值。對數(shù)組A使用Lbound 和bound函數(shù),其返回值列表如下 所有維的缺省下界取決于 Option Base 語句的

11、設(shè)置??梢钥闯鰧σ粩?shù)組使用LBound 函數(shù)與 UBound 函數(shù),可用于確定一個(gè)數(shù)組中元素的個(gè)數(shù)。對于那些在聲明中用 To 子句來設(shè)定維數(shù)的數(shù)組而言,它們可以用任何整數(shù)作為下界而不受Option Base 語句的限制。6數(shù)組的高級功能 盡管數(shù)組最通常被用來存儲成組的變量,但是在別的一些方面數(shù)組也是很有用的??梢詫⒁粋€(gè)數(shù)組的內(nèi)容賦值給另一個(gè)數(shù)組、創(chuàng)建返回?cái)?shù)組的函數(shù),還可以創(chuàng)建返回?cái)?shù)組的屬性。在許多情況下,這些技術(shù)能改進(jìn)應(yīng)用程序的性能。正如可以將一個(gè)變量的值賦給另一個(gè)變量,例如 StrA = StrB ,也可以將一個(gè)數(shù)組的內(nèi)容賦給另一個(gè)數(shù)組。例如,要將一字節(jié)型數(shù)組從一個(gè)位置復(fù)制到另一個(gè)位置??梢?/p>

12、通過每次復(fù)制一個(gè)字節(jié)來實(shí)現(xiàn),程序如下:Sub ByteCopy(oldCopy() As Byte, newCopy() As Byte)參數(shù)oldCopy()是源數(shù)組,newCopy()是目標(biāo)數(shù)組Dim i As IntegerReDim newCopy (Lbound(oldCopy) To UBound(oldCopy) 重新定義動態(tài)數(shù)組For i = Lbound(oldCopy) To Ubound(oldCopy) 循環(huán)賦值newCopy(i) = oldCopy(i)NextEnd Sub一個(gè)更有效的簡單的方法就是直接將一個(gè)數(shù)組賦給另外一個(gè)數(shù)組:Sub ByteCopy(oldC

13、opy() As Byte, newCopy() As Byte)參數(shù)oldCopy()是源數(shù)組,newCopy()是目標(biāo)數(shù)組newCopy = oldCopy 利用數(shù)組直接進(jìn)行賦值End Sub關(guān)于變量賦值有一些規(guī)則需要銘記。例如,雖然可以將一個(gè)聲明為整型的變量賦給一個(gè)聲明為長整型的變量而不會產(chǎn)生任何問題,但是將一個(gè)長整型變量賦給一個(gè)整型變量就很容易導(dǎo)致溢出錯(cuò)誤。除了遵守有關(guān)數(shù)據(jù)類型變量之間賦值時(shí)的規(guī)則外,數(shù)組賦值還要遵從另外一些規(guī)則,包括數(shù)組維數(shù),每一維的大小,以及數(shù)組是固定的還是動態(tài)的。維數(shù)、數(shù)據(jù)類型不同的數(shù)組賦值考慮的幾個(gè)因素l 賦值符左邊的數(shù)組類型:固定數(shù)組 (Dim x(1 to

14、10) As Integer) 或者動態(tài)數(shù)組 (Dim x() As Integer)。l 賦值符左邊數(shù)組的維數(shù)是否和賦值符右邊數(shù)組的維數(shù)匹配。l 賦值符兩邊數(shù)組的每一維的數(shù)組元素個(gè)數(shù)是否匹配。即使數(shù)組的聲明不同,維數(shù)也可能匹配。比如一個(gè)數(shù)組的每一維元素從 0 開始編號而另一個(gè)則從 1 開始,維數(shù)也可能匹配。l 賦值符兩邊所有元素的數(shù)據(jù)類型必須是相容的。這些規(guī)則和變量賦值的規(guī)則是一致的。表3-6顯示了這些因素的影響:數(shù)組賦值時(shí)的錯(cuò)誤可能發(fā)生在編譯時(shí),也可能發(fā)生在運(yùn)行時(shí)(例如,如果數(shù)據(jù)類型不能強(qiáng)制轉(zhuǎn)換或賦值試圖重新聲明 (ReDim) 一個(gè)靜態(tài)數(shù)組)。設(shè)計(jì)程序時(shí)要添加錯(cuò)誤處理以確保數(shù)組在賦值之前

15、是匹配的。編寫返回?cái)?shù)組的函數(shù)從一個(gè)函數(shù)返回一組值是可能實(shí)現(xiàn)的。例如,從一個(gè)函數(shù)返回一組字節(jié)而不必將其先轉(zhuǎn)換為一個(gè)字符串然后再轉(zhuǎn)換回來。下面是一個(gè)使用返回字節(jié)數(shù)組的函數(shù)的簡單示例:Private Sub Form_Load()Dim b As ByteDim i As IntegerDim ReturnArray() As Byteb = Cbyte(54)ReturnArray() = ArrayFunction(b) 調(diào)用函數(shù)For i = Lbound(ReturnArray) To Ubound(ReturnArray)Msgbox ReturnArray(i)通過彈出消息框循環(huán)顯示數(shù)組

16、值 NextEnd SubPublic Function ArrayFunction(b As Byte) As Byte()Dim x(2) As Bytex(0) = bx(1) = b + CByte(200)x(2) = b + bArrayFunction = x 返回結(jié)果為數(shù)組xEnd Function在運(yùn)行以上示例后, ReturnArray() 是一個(gè)三元素?cái)?shù)組,其中包含了分配給 ArrayFunction 中數(shù)組的值。ArrayFunction 語句將一個(gè)數(shù)組作為參數(shù)傳遞;且數(shù)組的數(shù)據(jù)類型必須和函數(shù)的數(shù)據(jù)類型相同(在本例中是字節(jié))。因?yàn)檫@是一個(gè)函數(shù)調(diào)用,傳遞數(shù)組時(shí)不必帶括號。注意: 盡管可以通過賦值給另一個(gè)數(shù)組(ArrayFunction = x()來返回一個(gè)數(shù)組,但出于性能方面的考慮,并不推薦使用這種方法。 必須為返回?cái)?shù)組的函數(shù)指定一個(gè)類型,這個(gè)類型可以是 Variant。這樣一來,F(xiàn)unction X() As Variant() 是有效的而 Function X() As () 將

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論