(2)加減算術(shù)運(yùn)算
對(duì)于指向數(shù)組的指針變量,可以加上或減去一個(gè)整數(shù)n。設(shè)pa是指向數(shù)組a的指針變量,則pa+n,pa-n,pa++,++pa,pa–,–pa 運(yùn)算都是合法的。指針變量加或減一個(gè)整數(shù)n的意義是把指針指向的當(dāng)前位置(指向某數(shù)組元素)向前或向后移動(dòng)n個(gè)位置。應(yīng)該注意,數(shù)組指針變量向前或向后移動(dòng)一個(gè)位置和地址加1或減1 在概念上是不同的。因?yàn)閿?shù)組可以有不同的類型, 各種類型的數(shù)組元素所占的字節(jié)長(zhǎng)度是不同的。如指針變量加1,即向后移動(dòng)1 個(gè)位置表示指針變量指向下一個(gè)數(shù)據(jù)元素的首地址。而不是在原地址基礎(chǔ)上加1。
例如:
int a[5],*pa;
pa=a; /*pa指向數(shù)組a,也是指向a[0]*/
pa=pa+2; /*pa指向a[2],即pa的值為&pa[2]*/ 指針變量的加減運(yùn)算只能對(duì)數(shù)組指針變量進(jìn)行, 對(duì)指向其它類型變量的指針變量作加減運(yùn)算是毫無(wú)意義的。(3)兩個(gè)指針變量之間的運(yùn)算只有指向同一數(shù)組的兩個(gè)指針變量之間才能進(jìn)行運(yùn)算, 否則運(yùn)算毫無(wú)意義。
①兩指針變量相減
兩指針變量相減所得之差是兩個(gè)指針?biāo)笖?shù)組元素之間相差的元素個(gè)數(shù)。實(shí)際上是兩個(gè)指針值(地址) 相減之差再除以該數(shù)組元素的長(zhǎng)度(字節(jié)數(shù))。例如pf1和pf2 是指向同一浮點(diǎn)數(shù)組的兩個(gè)指針變量,設(shè)pf1的值為2010H,pf2的值為2000H,而浮點(diǎn)數(shù)組每個(gè)元素占4個(gè)字節(jié),所以pf1-pf2的結(jié)果為(2000H-2010H)/4=4,表示pf1和 pf2之間相差4個(gè)元素。兩個(gè)指針變量不能進(jìn)行加法運(yùn)算。 例如, pf1+pf2是什么意思呢?毫無(wú)實(shí)際意義。
②兩指針變量進(jìn)行關(guān)系運(yùn)算
指向同一數(shù)組的兩指針變量進(jìn)行關(guān)系運(yùn)算可表示它們所指數(shù)組元素之間的關(guān)系。例如:
pf1==pf2表示pf1和pf2指向同一數(shù)組元素
pf1>pf2表示pf1處于高地址位置
pf1<pf2表示pf2處于低地址位置
main(){
int a=10,b=20,s,t,*pa,*pb;
pa=&a;
pb=&b;
s=*pa+*pb;
t=*pa**pb;
printf(“a=%dnb=%dna+b=%dna*b=%dn”,a,b,a+b,a*b);
printf(“s=%dnt=%dn”,s,t);
}
……
說(shuō)明pa,pb為整型指針變量
給指針變量pa賦值,pa指向變量a。
給指針變量pb賦值,pb指向變量b。
本行的意義是求a+b之和,(*pa就是a,*pb就是b)。
本行是求a*b之積。
輸出結(jié)果。
輸出結(jié)果。
……
指針變量還可以與0比較。設(shè)p為指針變量,則p==0表明p是空指針,它不指向任何變量;p!=0表示p不是空指針??罩羔樖怯蓪?duì)指針變量賦予0值而得到的。例如: #define NULL 0 int *p=NULL; 對(duì)指針變量賦0值和不賦值是不同的。指針變量未賦值時(shí),可以是任意值,是不能使用的。否則將造成意外錯(cuò)誤。而指針變量賦0值后,則可以使用,只是它不指向具體的變量而已。
main(){
int a,b,c,*pmax,*pmin;
printf(“input three numbers:n”);
scanf(“%d%d%d”,&a,&b,&c);
if(a>b){
pmax=&a;
pmin=&b;
}
else{
pmax=&b;
pmin=&a;
}
if(c>*pmax) pmax=&c;
if(c<*pmin) pmin=&c;
printf(“max=%dnmin=%dn”,*pmax,*pmin);
}
……
pmax,pmin為整型指針變量。
輸入提示。
輸入三個(gè)數(shù)字。
如果第一個(gè)數(shù)字大于第二個(gè)數(shù)字...
指針變量賦值
指針變量賦值
指針變量賦值
指針變量賦值
判斷并賦值
判斷并賦值
輸出結(jié)果
……
數(shù)組指針變量的說(shuō)明和使用
指向數(shù)組的指針變量稱為數(shù)組指針變量。 在討論數(shù)組指針變量的說(shuō)明和使用之前,我們先明確幾個(gè)關(guān)系。
一個(gè)數(shù)組是由連續(xù)的一塊內(nèi)存單元組成的。 數(shù)組名就是這塊連續(xù)內(nèi)存單元的首地址。一個(gè)數(shù)組也是由各個(gè)數(shù)組元素(下標(biāo)變量) 組成的。每個(gè)數(shù)組元素按其類型不同占有幾個(gè)連續(xù)的內(nèi)存單元。 一個(gè)數(shù)組元素的首地址也是指它所占有的幾個(gè)內(nèi)存單元的首地址。 一個(gè)指針變量既可以指向一個(gè)數(shù)組,也可以指向一個(gè)數(shù)組元素, 可把數(shù)組名或第一個(gè)元素的地址賦予它。如要使指針變量指向第i號(hào)元素可以把i元素的首地址賦予它或把數(shù)組名加i賦予它。
設(shè)有實(shí)數(shù)組a,指向a的指針變量為pa,從圖6.3中我們可以看出有以下關(guān)系:
pa,a,&a[0]均指向同一單元,它們是數(shù)組a的首地址,也是0 號(hào)元素a[0]的首地址。pa+1,a+1,&a[1]均指向1號(hào)元素a[1]。類推可知a+i,a+i,&a[i]
指向i號(hào)元素a[i]。應(yīng)該說(shuō)明的是pa是變量,而a,&a[i]都是常量。在編程時(shí)應(yīng)予以注意。
main(){
int a[5],i;
for(i=0;i<5;i++){
a[i]=i;
printf(“a[%d]=%dn”,i,a[i]);
}
printf(“n”);
}
主函數(shù)
定義一個(gè)整型數(shù)組和一個(gè)整型變量
循環(huán)語(yǔ)句
給數(shù)組賦值
打印每一個(gè)數(shù)組的值
……
輸出換行
……
數(shù)組指針變量說(shuō)明的一般形式為:
類型說(shuō)明符 * 指針變量名
其中類型說(shuō)明符表示所指數(shù)組的類型。 從一般形式可以看出指向數(shù)組的指針變量和指向普通變量的指針變量的說(shuō)明是相同的。
引入指針變量后,就可以用兩種方法來(lái)訪問(wèn)數(shù)組元素了。
第一種方法為下標(biāo)法,即用a[i]形式訪問(wèn)數(shù)組元素。 在第四章中介紹數(shù)組時(shí)都是采用這種方法。
第二種方法為指針?lè)?,即采?(pa+i)形式,用間接訪問(wèn)的方法來(lái)訪問(wèn)數(shù)組元素。
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++){
printf(“a[%d]=%dn”,i,*pa);
pa++;
}
}
主函數(shù)
定義整型數(shù)組和指針
將指針pa指向數(shù)組a
循環(huán)
將變量i的值賦給由指針pa指向的a[]的數(shù)組單元
將指針pa指向a[]的下一個(gè)單元
……
指針pa重新取得數(shù)組a的首地址
循環(huán)
用數(shù)組方式輸出數(shù)組a中的所有元素
將指針pa指向a[]的下一個(gè)單元
……
……
下面,另舉一例,該例與上例本意相同,但是實(shí)現(xiàn)方式不同。
main(){
int a[5],i,*pa=a;
for(i=0;i<5;){
*pa=i;
printf(“a[%d]=%dn”,i++,*pa++);
}
}
主函數(shù)
定義整型數(shù)組和指針,并使指針指向數(shù)組a
循環(huán)
將變量i的值賦給由指針pa指向的a[]的數(shù)組單元
用指針輸出數(shù)組a中的所有元素,同時(shí)指針pa指向a[]的下一個(gè)單元
……
……
數(shù)組名和數(shù)組指針變量作函數(shù)參數(shù)
在第五章中曾經(jīng)介紹過(guò)用數(shù)組名作函數(shù)的實(shí)參和形參的問(wèn)題。在學(xué)習(xí)指針變量之后就更容易理解這個(gè)問(wèn)題了。 數(shù)組名就是數(shù)組的首地址,實(shí)參向形參傳送數(shù)組名實(shí)際上就是傳送數(shù)組的地址, 形參得到該地址后也指向同一數(shù)組。 這就好象同一件物品有兩個(gè)彼此不同的名稱一樣。同樣,指針變量的值也是地址, 數(shù)組指針變量的值即為數(shù)組的首地址,當(dāng)然也可作為函數(shù)的參數(shù)使用。
float aver(float *pa);
main(){
float sco[5],av,*sp;
int i;
sp=sco;
printf(“ninput 5 scores:n”);
for(i=0;i<5;i++) scanf(“%f”,&sco[i]);
av=aver(sp);
printf(“average score is %5.2f”,av);
}
float aver(float *pa)
{
int i;
float av,s=0;
for(i=0;i<5;i++) s=s+*pa++;
av=s/5;
return av;
}