




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
6.1指針與指針變量6.1.1指針在計算機中,內存由一個個具有連續編碼的存儲單元所組成,即每一個存儲單元都具有唯一的、固定的編號,這個編號稱為內存單元的地址。如果在程序中定義了一個變量,由于不同的數據類型占據不同字節的存儲空間,在編譯時,系統就根據程序中定義的變量類型,分配相應的存儲空間。例如,對整型變量分配2個字節,對實型變量分配4個字節,對字符型變量分配1個字節,而每一個字節都有一個地址。每個變量的首字節的地址稱為該變量的地址。一個變量的地址稱為這個變量的指針,指針就是地址。內存中的地址常用十六進制整型數表示。如何查看一個變量的地址呢?可以用取地址運算符“&”來實現。如運行以下程序:main(){inta=26;printf("&a=%x,a=%d\n",&a,a);}可以查看整型變量a的地址(a占2個字節,看到的是它的首字節的地址)和a的值。
6.1.2直接訪問和間接訪問在C語言的程序中,一般是通過變量名對內存單元進行存取操作的。程序經過編譯以后將變量名轉換為變量的地址,對變量值的存取都是通過地址進行的。像這種直接按變量地址存取變量值的方式稱為“直接訪問”。如對以下程序:main(){inta,b,c;a=10;b=16;c=a+b;printf("%d\n",c);}
變量的“間接訪問”方式是將變量a的地址存放在另一個稱為“指針變量”的變量中,當要讀取變量a的值時,先從指針變量中取出a的地址,再從這個地址單元中取出a的值。
6.1.3指針變量的定義和引用如前所述,變量的地址就是變量的指針,存放變量指針(地址)的變量稱為指針變量。指針變量的使用和其他變量的使用一樣需要“先定義,后使用”。1.指針變量的定義
指針變量不同于其他變量,它是用來專門存放地址的,必須將它定義為“指針類型”。指針變量定義的一般形式為:數據類型*指針變量名其中,“數據類型”說明該指針變量所指向的變量類型,“*”表示所定義的變量是一個指針變量而不是一個普通變量。例如:inta,b,*pa,*pb;pa=&a;pb=&b;定義了整型變量a、b及指針變量pa、pb,且pa、pb是用來指向整型變量的(即用來存放整型變量的地址)。“&”是取地址運算符,pa=&a將變量a的地址存放到指針變量pa中,pb=&b將變量b的地址存放到指針變量pb中。在定義指針變量時可以賦給初值,例如:inta,b,*pa=&a,*pb=&b;
2.指針變量的引用
在定義了一個指針變量并確定了它的指向后,就可以利用它來訪問所指向的變量,稱為對指針變量的引用。引用指針變量的一般形式為:*指針變量名這里的“*”稱為指針運算符,也稱為“間接訪問”運算符。
[例6-1]
指針變量的引用。程序如下:main(){inta,b,*pa,*pb;pa=&a;pb=&b;a=2;b=4;printf("%d,%d\n",*pa,*pb);*pa=10;*pb=20;printf("%d,%d\n",a,b)}程序運行結果:2,410,20注意:在C語言中,“*”符號目前已出現三種用法,一是乘法符號;二是指針變量定義符;三是指針變量引用符。在上例中,“先定義”指針變量,“后使用”——給它賦值(變量的地址)、引用它。等同于變量a*pa變量a的地址&apa=&a6.2指針運算與其他變量一樣,指針也是一種特殊的變量,也有指針運算。其中最常用的運算有:取地址運算&,取值運算*,以及指針加、減運算等。1.取地址運算&取地址運算是指取出運算符&后面的變量在內存中占用的空間的起始地址。因為被指向的變量可能占用多個內存單元,指針并不記錄它的所有地址,而只指向它的起始地址。2.取數據運算*與取地址運算符“&”相對應的是取數據運算符“*”,也稱指針運算符。取地址運算的操作對象是變量,而取數據運算的操作對象則是指針變量,用于訪問某個地址的數據。“*”運算符除作為取數據運算符外,還作為定義指針變量標識符,另外還可作為算術乘法運算符。對于“*”在不同場合的作用,編譯器能夠根據上下文環境判別其作用。3.指針變量的算術運算
在C語言中,可以通過加減一個整數來移動指針。指針增1運算后指向下一個數據(注意不是下一個字節)的位置,指針減1運算后指向上一個數據的位置。例如:inta,*pa;pa=&a;pa++;在這段程序中,定義pa為指向整型變量的指針變量,則pa++相當于pa=pa+1×2(每個整型變量在內存中占兩個字節),即pa++使指針向下移動兩個字節指向下一個數據。6.3指針與數組指針與數組關系密切。一個數組包含若干元素,每個數組元素都在內存中占用存儲單元,它們都有相應的地址。因此,指針變量可以指向數組和數組元素。數組的指針是數組的起始地址,數組元素的指針是數組元素的地址。使用指針可以對數組進行相關的操作。6.3.1指向一維數組的指針變量C語言規定一維數組的數組名代表數組的首地址,因此數組名本身就是一個指針,它指向第1個數組元素。其他數組元素的地址可以通過數組名加偏移量來取得。例如:
inta[20];/*定義一個長度為20的一維數組a,數組元素為整型*/
int*pa;/*定義指向整型數據的指針變量pa*/pa=a;/*為指針變量賦值,注意:數組名前不加&*/
pa=&a[0];/*本語句與上句等價*/注意:上述“pa=a;”的作用是“把a數組的首地址賦給指針變量pa”,“而不是把數組a各元素的值賦給pa”。一維數組指針的應用十分靈活。例如:如果定義
inta[20],*p=a;
既定義了一個有20個元素的一維整型數組;定義了一個整型指針變量;并將數組的首地址賦給這個指針變量。則(1)數組第i個元素的地址可以用下述方法表示:&a[i]或a+i或p+i;(2)數組第i個元素的值可以用下述方法表示:a[i]或p[i]或*(a+i)或*(p+i);
[例6-3]
假設有一個整型的a數組,共有20個元素。要求從鍵盤輸入這20個元素,并利用下標法、數組名法和指針法等3種方法輸出數組中的各元素。
方法一:下標法
main(){int
a[20],i;for(i=0;i<20;i++)scanf("%d",&a[i]);for(i=0;i<20;i++)printf("%d",&a[i]);}方法二:數組名法main(){int
a[20],i;for(i=0;i<20;i++)scanf("%d",a+i);for(i=0;i<20;i++)printf("%d",*(a+i));}方法三:指針法main(){inta[20],i,*p;p=a;for(i=0;i<20;i++)scanf("%d",p+i);pa=a;for(i=0;i<20;i++)printf("%d",*(p+i));}6.3.2指向二維數組的指針變量用指針處理一維數組時,指針變量所指對象為數組元素,即指針變量增1、減1操作就使指針后移或前移一個數組元素。但是指針處理二維數組時,指針變量所指對象是二維數組中的行,因此,無論從概念上還是使用上,二維數組的指針都要比一維數組的指針更加靈活。1.二維數組的地址
對二維數組a[3][4],
C語言將它視為有三個元素a[0]、a[1]、a[2]的一維數組(而每一個元素又是一個一維數組),
a代表整個二維數組的首地址。所以根據一維數組的表示方法,a+i代表第i個元素的地址(即第i行的首地址),a[i]和
*(a+i)表示它的第i個元素,但是這第i個元素又是一個一維數組,數組名就是這個數組的首地址,所以a[i]和
*(a+i)也代表第i個元素的地址(即第i行的首地址)。因此,對二維數組a[3][4]:(1)第i行的首地址可用下述方法表示:&a[i][0]或a+i或a[i]
或*(a+i);(2)第i行第j列的元素的地址可用下述方法表示:
&a[i][j]或(a+i)+j或a[i]+j
或*(a+i)+j
或a[0]+i*4+j等等;(3)第i行第j列的元素的值可用下述方法表示:
a[i][j]或*((a+i)+j)或*(a[i]+j)或*(*(a+i)+j);2.指向二維數組的指針變量
(1)指向數組元素的指針變量[例6-5]
用指針變量輸出二維數組元素的值。程序如下:main(){int
a[3][4]={{2,4,6,8},{10,12,14,16},{18,20,22,24}};int*p;/*定義一個指向整型變量的指針變量*/for(p=a[0];p<a[0]+12;p++){if((p-a[0])%4==0)
printf("\n");printf("%4d",*p);}}程序中用a[0]至a[0]+11表示各元素的地址。(2)指向一維數組的指針變量
把二維數組a分解為一維數組a[0]、a[1]、a[2]之后,設p為指向該一維數組的指針變量,可定義為:int(*p)[4];它表示p是一個指針變量,指向包含4個元素的一維數組。若p指向第一個一維數組a[0],其值等于a、a[0]或&a[0][0],而p+i則指向一維數組a[i]。從前面的分析可得出*(p+i)+j是二維數組第i行j列的元素的地址,而*(*(p+i)+j)則是第i行j列元素的值。
[例6-6]
輸出二維數組任一行任一列元素的值。main(){inta[2][3]={1,2,3,4,5,6};int(*p)[3],i,j;p=a;scanf("i=%d,j=%d",&i,&j);printf("a[%d][%d]=%d\n",i,j,*(*(p+i)+j));}程序運行結果:輸入i=0,j=2回車,屏幕顯示:a[0][2]=36.3.3指針數組
當一個數組的所有元素都是指針時,它就是一個指針數組,即指針數組中的每一個元素都相當于一個指針變量。一維指針數組的定義形式為:
類型名*數組名[數組長度];例如:
inta[3][4]={2,4,6,8,10,12,14,16,18,20,22,24};int*p[3]={a[0],a[1],a[2]};/*為指針數組賦初值*/指針數組中的每個元素被賦予二維數組每一行的首地址。6.4指針與字符串C語言可以用字符指針來處理字符串。例如:char
str[30],*ps=str;又例如:char
*ps="Iamastudent!“;雖然用字符數組和字符指針變量都能實現字符串的存儲和運算,但它們二者之間是有區別的,不能混為一談,主要區別有以下幾點:(1)字符數組由若干個元素組成,每個元素中放一個字符,而字符指針變量中存放的是地址(即字符串的首地址)。(2)賦值方式不同。(3)字符指針變量的值是可以改變的,如下列程序:main(){char
*a="Iamastudent!";a=a+7;printf("%s",a);}程序運行結果:
student!由程序可以看出,指針變量a的值可以變化,輸出字符串時從變化了的a值所指向的單元開始輸出各個字符,直到遇到字符串結束符‘\0’為止。而字符數組名雖然代表地址,但它的值是不能改變的。下面的寫法是錯的:char
s[]="Iamastudent!";s=s+7;printf("%s\n",s);6.5指針與函數指針變量既可以指向整型變量、數組、字符串,也可以指向函數。一個函數被執行時,在內存中占據一定的空間,這個空間的起始地址稱為函數的入口地址,用函數名表示。可以用指針變量指向這個入口地址,并通過該指針變量調用此函數,這種指針變量稱為指向函數的指針。它定義的一般形式為:數據類型
(*指針變量名)();定義了函數指針后,就可以通過它來調用所指向的函數。在調用之前,必須先將函數的入口地址賦給該指針變量。由于函數名代表函數的入口地址,因此給函數指針變量賦值時,只需給出函數名而不必給出參數。
[例6-9]
從鍵盤輸入10個數,找出其中的最小值并輸出。程序如下:#include<stdio.h>intfmin(inta[],intn){inti,min;min=a[0];
for(i=1;i<n;i++)if(min>a[i])min=a[i];return(min);}main(){int(*p)();inti,mini,a[10];for(i=0;i<10;i++)scanf("%d",&a[i]);p=fmin;/*給指針變量賦初值*/mini=(*p)(a,10);/*調用由指針變量p指向的fmin()函數,實參為a、10,得到的函數返回值賦給mini。*/
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 企業勞動合同規定
- 土建工程承包合同意向書
- 企業管理咨詢培訓合同書
- 支付勞動合同報酬
- 貨物貿易的居間合同
- 協議合同草稿
- 合同轉讓變更協議
- 安保合同框架協議
- 復印合同協議拼音
- 合同分紅協議
- 用Excel求解運籌學中最大流問題詳細操作示例
- 民航客艙服務藝術案例分析全套PPT完整教學課件
- GB/T 4857.7-2005包裝運輸包裝件基本試驗第7部分:正弦定頻振動試驗方法
- GB/T 13936-1992硫化橡膠與金屬粘接拉伸剪切強度測定方法
- GB/T 12689.1-2010鋅及鋅合金化學分析方法第1部分:鋁量的測定鉻天青S-聚乙二醇辛基苯基醚-溴化十六烷基吡啶分光光度法、CAS分光光度法和EDTA滴定法
- GB/T 11344-2021無損檢測超聲測厚
- 生涯適應力量表
- 抗菌藥物臨床應用指導原則(最新)
- 正壓空氣呼吸器檢查使用實操考評表
- 《嚴重創傷》課件
- 跨道施工保通方案(門洞式)
評論
0/150
提交評論