c语言两个指针变量不可以,2.C语言指针变量
# 2.C語(yǔ)言指針變量
變量的指針就是變量的地址。存放變量地址的變量是指針變量。即在C語(yǔ)言中,允許用一個(gè)變量來(lái)存放指針,這種變量稱為指針變量。因此,一個(gè)指針變量的值就是某個(gè)變量的地址或稱為某變量的指針。
為了表示指針變量和它所指向的變量之間的關(guān)系,在程序中用“*”符號(hào)表示“指向”,例如,i_pointer代表指針變量,而*i_pointer是i_pointer所指向的變量。因此,下面兩個(gè)語(yǔ)句作用相同:
~~~
i=3;
*i_pointer=3;
~~~
第2個(gè)語(yǔ)句的含義是將3賦給指針變量i_pointer所指向的變量。
## 定義一個(gè)指針變量
對(duì)指針變量的定義包括三個(gè)內(nèi)容:
1. 指針類型說(shuō)明,即定義變量為一個(gè)指針變量;
2. 指針變量名;
3. 變量值(指針)所指向的變量的數(shù)據(jù)類型。
其一般形式為:
類型說(shuō)明符? *變量名;
其中,*表示這是一個(gè)指針變量,變量名即為定義的指針變量名,類型說(shuō)明符表示本指針變量所指向的變量的數(shù)據(jù)類型。
例如:
~~~
int *p1;
~~~
表示p1是一個(gè)指針變量,它的值是某個(gè)整型變量的地址。或者說(shuō)p1指向一個(gè)整型變量。至于p1究竟指向哪一個(gè)整型變量,應(yīng)由向p1賦予的地址來(lái)決定。
再如:
~~~
int *p2; /*p2是指向整型變量的指針變量*/
float *p3; /*p3是指向浮點(diǎn)變量的指針變量*/
char *p4; /*p4是指向字符變量的指針變量*/
~~~
應(yīng)該注意的是,一個(gè)指針變量只能指向同類型的變量,如P3 只能指向浮點(diǎn)變量,不能時(shí)而指向一個(gè)浮點(diǎn)變量,時(shí)而又指向一個(gè)字符變量。
## 指針變量的引用
指針變量同普通變量一樣,使用之前不僅要定義說(shuō)明,而且必須賦予具體的值。未經(jīng)賦值的指針變量不能使用,否則將造成系統(tǒng)混亂,甚至死機(jī)。指針變量的賦值只能賦予地址,決不能賦予任何其它數(shù)據(jù),否則將引起錯(cuò)誤。在C語(yǔ)言中,變量的地址是由編譯系統(tǒng)分配的,對(duì)用戶完全透明,用戶不知道變量的具體地址。
兩個(gè)有關(guān)的運(yùn)算符:
* &:取地址運(yùn)算符;
* *:指針運(yùn)算符(或稱“間接訪問(wèn)” 運(yùn)算符)。
C語(yǔ)言中提供了地址運(yùn)算符&來(lái)表示變量的地址。其一般形式為:
&變量名;
如&a表示變量a的地址,&b表示變量b的地址。變量本身必須預(yù)先說(shuō)明。
設(shè)有指向整型變量的指針變量p,如要把整型變量a 的地址賦予p可以有以下兩種方式:
1. 指針變量初始化的方法:
~~~
int a;
int *p=&a;
~~~
2. 賦值語(yǔ)句的方法:
~~~
int a;
int *p;
p=&a;
~~~
不允許把一個(gè)數(shù)賦予指針變量,故下面的賦值是錯(cuò)誤的:
~~~
int *p;
p=1000;
~~~
被賦值的指針變量前不能再加“*”說(shuō)明符,如寫(xiě)為*p=&a 也是錯(cuò)誤的。假設(shè):
~~~
int i=200, x;
int *ip;
~~~
我們定義了兩個(gè)整型變量i、x,還定義了一個(gè)指向整型數(shù)的指針變量ip。i、x中可存放整數(shù),而ip中只能存放整型變量的地址。我們可以把i的地址賦給ip:
~~~
ip=&i;
~~~
此時(shí)指針變量ip指向整型變量i,假設(shè)變量i的地址為1800,這個(gè)賦值可形象理解為下圖所示的聯(lián)系。

以后我們便可以通過(guò)指針變量ip間接訪問(wèn)變量i,例如:
~~~
x=*ip;
~~~
運(yùn)算符*訪問(wèn)以ip為地址的存貯區(qū)域,而ip中存放的是變量i的地址,因此,*ip訪問(wèn)的是地址為1800的存貯區(qū)域(因?yàn)槭钦麛?shù),實(shí)際上是從1800開(kāi)始的兩個(gè)字節(jié)),它就是i所占用的存貯區(qū)域,所以上面的賦值表達(dá)式等價(jià)于:
~~~
x=i;
~~~
另外,指針變量和一般變量一樣,存放在它們之中的值是可以改變的,也就是說(shuō)可以改變它們的指向,假設(shè)
~~~
int i, j, *p1, *p2;
i='a';
j='b';
p1=&i;
p2=&j;
~~~
則建立如下圖所示的聯(lián)系。

這時(shí)賦值表達(dá)式:
~~~
p2=p1;
~~~
就使p2與p1指向同一對(duì)象i,此時(shí)*p2就等價(jià)于i,而不是j,圖所示。

如果執(zhí)行如下表達(dá)式:
~~~
*p2=*p1;
~~~
則表示把p1指向的內(nèi)容賦給p2所指的區(qū)域,此時(shí)就變成下圖所示。

通過(guò)指針訪問(wèn)它所指向的一個(gè)變量是以間接訪問(wèn)的形式進(jìn)行的,所以比直接訪問(wèn)一個(gè)變量要費(fèi)時(shí)間,而且不直觀,因?yàn)橥ㄟ^(guò)指針要訪問(wèn)哪一個(gè)變量,取決于指針的值(即指向),例如"*p2=*p1;"實(shí)際上就是"j=i;",前者不僅速度慢而且目的不明。但由于指針是變量,我們可以通過(guò)改變它們的指向,以間接訪問(wèn)不同的變量,這給程序員帶來(lái)靈活性,也使程序代碼編寫(xiě)得更為簡(jiǎn)潔和有效。
指針變量可出現(xiàn)在表達(dá)式中,設(shè)
~~~
int x, y, *px=&x;
~~~
指針變量px指向整數(shù)x,則*px可出現(xiàn)在x能出現(xiàn)的任何地方。例如:
~~~
y=*px+5; /*表示把x的內(nèi)容加5并賦給y*/
y=++*px; /*px的內(nèi)容加上1之后賦給y,++*px相當(dāng)于++(*px)*/
y=*px++; /*相當(dāng)于y=*px; px++*/
~~~
【例10-1】
~~~
main(){
int a,b;
int *pointer_1, *pointer_2;
a=100;b=10;
pointer_1=&a;
pointer_2=&b;
printf("%d,%d\n",a,b);
printf("%d,%d\n",*pointer_1, *pointer_2);
}
~~~
對(duì)程序的說(shuō)明:
1. 在開(kāi)頭處雖然定義了兩個(gè)指針變量pointer_1和pointer_2,擔(dān)它們并未指向任何一個(gè)整型變量。只是提供兩個(gè)指針變量,規(guī)定它們可以指向整型變量。程序第4、5行的作用就是使pointer_1指向a,pointer_2指向b。
2. 最后一行的*pointer_1和*pointer_2就是變量a和b。最后兩個(gè)printf函數(shù)作用是相同的。
3. 程序中有兩處出現(xiàn)*pointer_1和*pointer_2,請(qǐng)區(qū)分它們的不同含義。
4. 程序第4、5行的“pointer_1=&a”和 “pointer_2=&b”不能寫(xiě)成“*pointer_1=&a”和 “*pointer_2=&b”。
請(qǐng)對(duì)下面再的關(guān)于“&”和“*”的問(wèn)題進(jìn)行考慮:
1. 如果已經(jīng)執(zhí)行了“pointer_1=&a;”語(yǔ)句,則&*pointer_1是什么含義?
2. *&a含義是什么?
3. (pointer_1)++和pointer_1++的區(qū)別?
【例10-2】輸入a和b兩個(gè)整數(shù),按先大后小的順序輸出a和b。
~~~
main(){
int *p1,*p2,*p,a,b;
scanf("%d,%d",&a,&b);
p1=&a;p2=&b;
if(a
p=p1;
p1=p2;
p2=p;
}
printf("\na=%d,b=%d\n",a,b);
printf("max=%d,min=%d\n",*p1, *p2);
}
~~~
總結(jié)
以上是生活随笔為你收集整理的c语言两个指针变量不可以,2.C语言指针变量的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 【理财入门二】复利思维
- 下一篇: 仅仅有人物没背景的图片怎么弄_纯干货//