單片機C語(yǔ)言教程:C51數組的使用
數組不過(guò)就是同一類(lèi)型變量的有序集合。形象的能這樣去理解,就像一個(gè) 學(xué)校在操場(chǎng)上排隊,每一個(gè)級代表一個(gè)數據類(lèi)型,每一個(gè)班級為一個(gè)數組,每一個(gè)學(xué)生就是 數組中的一個(gè)數據。數據中的每個(gè)數據都能用唯一的下標來(lái)確定其位置,下標能是一維 或多維的。就如在學(xué)校的方隊中要找一個(gè)學(xué)生,這個(gè)學(xué)生在 I 年級 H 班 X 組 Y 號的,那么 能把這個(gè)學(xué)生看做在 I 類(lèi)型的 H 數組中(X,Y)下標位置中。數組和普通變量一樣,要
本文引用地址:http://dyxdggzs.com/article/170573.htm求先定義了才能使用,下面是定義一維或多維數組的方式:
“數據類(lèi)型”是指數組中的各數據單元的類(lèi)型,每個(gè)數組中的數據單元只能是同一數據
類(lèi)型。“數組名”是整個(gè)數組的標識,命名方法和變量命名方法是一樣的。在編譯時(shí)系統會(huì ) 根據數組大小和類(lèi)型為變量分配空間,數組名能說(shuō)就是所分配空間的首地址的標識。“常 量表達式”是表示數組的長(cháng)度和維數,它必須用“[]”括起,括號里的數不能是變量只能是 常量。
unsigned int xcount [10]; //定義無(wú)符號整形數組,有 10 個(gè)數據單元
char inputstring [5]; //定義字符形數組,有 5 個(gè)數據單元
float outnum [10],[10];//定義浮點(diǎn)型數組,有 100 個(gè)數據單元
在 C 語(yǔ)言中數組的下標是從 0 開(kāi)始的而不是從 1 開(kāi)始,如一個(gè)具有 10 個(gè)數據單元的數
組 count,它的下標就是從 count[0]到 count[9],引用單個(gè)元素就是數組名加下標,如 count[1] 就是引用 count 數組中的第 2 個(gè)元素,如果錯用了 count[10]就會(huì )有錯誤出現了。還有一點(diǎn)要 注意的就是在程序中只能逐個(gè)引用數組中的元素,不能一次引用整個(gè)數組,但是字符型的數 組就能一次引用整個(gè)數組。
數組也是能賦初值的。在上面介紹的定義方式只適用于定義在內存 DATA 存儲器使 用的內存,有的時(shí)候我們需要把一些數據表存放在數組中,通常這些數據是不用在程序中改 變數值的,這個(gè)時(shí)候就要把這些數據在程序編寫(xiě)時(shí)就賦給數組變量。因為 51 芯片的片內 RAM 很有限,通常會(huì )把 RAM 分給參與運算的變量或數組,而那些程序中不變數據則應存放在片 內的 CODE 存儲區,以節省寶貴的 RAM。賦初值的方式如下:
數據類(lèi)型 [存儲器類(lèi)型] 數組名 [常量表達式] = {常量表達式};
數據類(lèi)型 [ 存儲器類(lèi)型] 數組名 [ 常量表達式 1]...... [ 常量表達式 N]={{ 常量表達 式}...{常量表達式 N}};
在定義并為數組賦初值時(shí),開(kāi)始學(xué)習的朋友一般會(huì )搞錯初值個(gè)數和數組長(cháng)度的關(guān)系,而致使 編譯出錯。初值個(gè)數必須小于或等于數組長(cháng)度,不指定數組長(cháng)度則會(huì )在編譯時(shí)由實(shí)際的初值 個(gè)數自動(dòng)設置。
unsigned char LEDNUM[2]={12,35}; //一維數組賦初值
int Key[2][3]={{1,2,4},{2,2,1}}; //二維數組賦初值
unsigned char IOStr[]={3,5,2,5,3}; //沒(méi)有指定數組長(cháng)度,編譯器自動(dòng)設置
unsigned char code skydata[]={0x02,0x34,0x22,0x32,0x21,0x12}; //數據保存在 code 區
下面的一個(gè)簡(jiǎn)單例子是對數組中的數據進(jìn)行排序,使用的是冒泡法,一來(lái)了解數組的使 用,二來(lái)掌握基本的排序算法。冒泡排序算法是一種基本的排序算法,它每次順序取數組中 的兩個(gè)數,并按需要按其大小排列,在下一次循環(huán)中則取下一次的一個(gè)數和數組中下一個(gè)數 進(jìn)行排序,直到數組中的數據全部排序完成。
#include
#include
void taxisfun (int taxis2[])
{
unsigned char TempCycA,TempCycB,Temp;
for (TempCycA=0; TempCycA=8; TempCycA++)
for (TempCycB=0; TempCycB=8-TempCycA; TempCycB++)
{//TempCycB8-TempCycA 比用 TempCycB=8 少用很多循環(huán)
if (taxis2[TempCycB+1]>taxis2[TempCycB]) //當后一個(gè)數大于前一個(gè) 數
{
Temp = taxis2[TempCycB]; //前后 2 數交換
taxis2[TempCycB] = taxis2[TempCycB+1];
taxis2[TempCycB+1] = Temp; //因函數參數是數組名調用形
參的變動(dòng)影響實(shí)參
}
}
}
void main(void)
{
int taxis[] = {113,5,22,12,32,233,1,21,129,3};
char Text1[] = {source data:}; //源數據
char Text2[] = {sorted data:}; //排序后數據
unsigned char TempCyc;
SCON = 0x50; //串行口方式 1,允許接收
TMOD = 0x20; //定時(shí)器 1 定時(shí)方式 2
TCON = 0x40; //設定時(shí)器 1 開(kāi)始計數
TH1 = 0xE8; //11.0592MHz 1200 波特率
TL1 = 0xE8; TI = 1;
TR1 = 1; //啟動(dòng)定時(shí)器
printf(%sn,Text1); //字符數組的整體引用
for (TempCyc=0; TempCyc10; TempCyc++)
printf(%d ,taxis[TempCyc]);
printf(n----------n);
taxisfun (taxis); //以實(shí)際參數數組名 taxis 做參數被函數調用
printf(%sn,Text2);
for (TempCyc=0; TempCyc10; TempCyc++) //調用后 taxis 會(huì )被改變
printf(%d ,taxis[TempCyc]);
while(1);
}
例子中能看出,數組同樣能作為函數的參數進(jìn)行傳遞。數組做參數時(shí)是用數組名進(jìn)行傳遞的,一個(gè)數組的數組名表示該數組的首地址,在用數組名作為函數的調用參數時(shí),它 的傳遞方式是采用了地址傳遞,就是將實(shí)際參數數組的首地址傳遞給函數中的形式參數數 組,這個(gè)時(shí)候實(shí)際參數數組和形式參數數組實(shí)際上是使用了同一段內存單元,當形式參數數組在 函數體中改變了元素的值,同時(shí)也會(huì )影響到實(shí)際參數數組,因為它們是存放在同一個(gè)地址的。 上面的例子同時(shí)還使用到字符數組。字符數組中每一個(gè)數據都是一個(gè)字符,這樣一個(gè)一 維的字符數組就組成了一個(gè)字符串,在 C 語(yǔ)言中字符串是以字符數組來(lái)表達處理的。為了 能測定字符串的長(cháng)度,C 語(yǔ)言中規定以‘o’來(lái)做為字符串的結束標識,編譯時(shí)會(huì )自動(dòng)在字 符串的最后加入一個(gè)‘o’,那么要注意的是如果用一個(gè)數組要保存一個(gè)長(cháng)度為 10 字節的字 符串則要求這個(gè)數組至少能保存 11 個(gè)元素。‘o’是轉義字符,它的含義是空字符,它的 ASCII 碼為 00H,也就是說(shuō)當每一個(gè)字符串都是以數據 00H 結束的,在程序中操作字符數 據組時(shí)要注意這一點(diǎn)。字符數組除了能對數組中單個(gè)元素進(jìn)行訪(fǎng)問(wèn),還能訪(fǎng)問(wèn)整個(gè)數組, 其實(shí)整個(gè)訪(fǎng)問(wèn)字符數組就是把數組名傳到函數中,數組名是一個(gè)指向數據存放空間的地址指 針,函數根據這個(gè)指針和‘/o’就能完整的操作這個(gè)字符數組。對于這一段所說(shuō)的,能 參看下面一例 1602LCD 顯示模塊的驅動(dòng)演示例子進(jìn)行理解。這里要注意就是能用單個(gè)字符數組元素來(lái)進(jìn)行運算,但不能用整個(gè)數組來(lái)做運算,因為數組名是指針而不是數據。
c語(yǔ)言相關(guān)文章:c語(yǔ)言教程
c++相關(guān)文章:c++教程
評論