指向一維陣列的指標變數和指向二維陣列的指標變數---注意其指標表示
指向一維陣列的指標變數和指向二維陣列的指標變數以及指標陣列的區別
一、指向一維陣列的指標變數 設一維陣列為a[n]
定義方法: *指標變數名 即 *P
這個p一般指向的一維陣列的首地址,即p=a,或者p=&a[0];p,a,&a[0]均指向同一單元,它們是陣列a的首地址,也是0 號元素a[0]的首地址。p+1,a+1,&a[1]均指向1號元素a[1]。類推可知a+i,a+i,&a[i]。
例子:
main(){int a[5],i,*pa;pa=a;for(i=0;i<5;i++){*pa=i;pa++;}pa=a;for(i=0;i<5;i++){
二、指向二維陣列的指標變數 設一維陣列為a[m][n]
定義方法: (*指標變數名)[長度] 即 (*P)[n]
“長度”表示二維陣列分解為多個一維陣列時, 一維陣列的長度,也就是二維陣列的列數。
1、多維陣列有關概念
注意a[0],a[1],a[2]表示的都是對應那行的陣列首地址,和陣列名,而不是一個元素
多維陣列地址的表示方法設有整型二維陣列a[3][4]如下:0 1 2 34 5 6 78 9 10 11 設陣列a的首地址為1000,各下標變數的首地址及其值如圖所示。在第四章中介紹過, C語言允許把一個二維陣列分解為多個一維陣列來處理。因此陣列
2、指向二維數的指標變數
定義方法: (*指標變數名)[長度] 即 (*P)[n]
注意:二維陣列i行j 列的元素的地址的表示方法*(p+i)+j。把二維陣列a 分解為一維陣列a[0],a[1],a[2]之後,設p為指向二維陣列的指標變數。可定義為: int (*p)[4] 它表示p是一個指標變數,它指向二維陣列a 或指向第一個一維陣列a[0],其值等於a,a[0],或&a[0][0]等。而p+i則指向一維陣列a[i]。從前面的分析可得出*(p+i)+j是二維陣列i行j 列的元素的地址,而*(*(p+i)+j)則是i行j列元素的值。二維陣列指標變數說明的一般形式為: 型別說明符 (*指標變數名)[長度] 其中“型別說明符”為所指陣列的資料型別。“*”表示其後的變數是指標型別。 “長度”表示二維陣列分解為多個一維陣列時, 一維陣列的長度,也就是二維陣列的列數。應注意“(*指標變數名)”兩邊的括號不可少,如缺少括號則表示是指標陣列(本章後面介紹),意義就完全不同了。[Explain]main(){static int a[3][4]={0,1,2,3,4,5,6,7,8,9,10,11};int(*p)[4];int i,j;p=a;for(i=0;i<3;i++)for(j=0;j<4;j++) printf("%2d ",*(*(p+i)+j));
三、指向二維陣列的指標變數
定義方法: *指標變數名[陣列長度] 即 *P[n],每個元素都是指標,即存了n個地址
注意這裡P兩側沒有括號,區別於指向多維陣列的指標。
常用語含有多個字串的陣列,如:
static char *name[]={ "Illegal day","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"};
這裡name[0],name[1]-----name[7]分別表示這七個字串的首地址。
分析上述原因,個人覺得是因為以下區別:
使用字串指標變數與字元陣列的區別
字串指標變數本身是一個變數,用於存放字串的首地址。而字串本身是存放在以該首地址為首的一塊連續的記憶體空間中並以‘\0’作為串的結束。字元陣列是由於若干個陣列元素組成的,它可用來存放整個字串。1、對字元陣列作初始化賦值,必須採用外部型別或靜態型別,如: static char st[]={“C Language”};而對字串指標變數則無此限制,如: char *ps="C Language";2、對字串指標方式 char *ps="C Language";可以寫為: char *ps;ps="C Language";
故對於陣列*name[]={ "Illegal day","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"};可將每個字串的首地址賦予陣列的個元素name[0]----name[7];
而對陣列方式:static char st[]={"C Language"};不能寫為:char st[20];st={"C Language"};
而只能對字元陣列的各元素逐個賦值。