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














評論