基于指針的數(shù)據(jù)類型與指針運(yùn)算小結(jié)
1.指針的數(shù)據(jù)類型小結(jié)
有關(guān)指針的數(shù)據(jù)類型
定義 | 含義 |
---|---|
int i; | 定義整形變量 |
int *p; | 定義只想整型數(shù)據(jù)的指針變量p |
int a[n]; | 定義整形數(shù)組a,它有n個(gè)元素 |
int *p[n]; | 定義指針數(shù)組p,它由n個(gè)指向整形數(shù)據(jù)類型的指針元素組成 |
int (*p)[n]; | 定義指向n個(gè)元素的一位數(shù)組的指針變量 |
int f(); | f為帶回整形函數(shù)值的函數(shù) |
int *p(); | p為帶回一個(gè)指針的函數(shù),該指針指向整形數(shù)據(jù)。 |
int (*p)(); | p為指向函數(shù)的指針,該函數(shù)返回一個(gè)整形數(shù)據(jù) |
int * *p; | p為一個(gè)指向指針的指針變量,它指向一個(gè)整形數(shù)據(jù)的指針變量 |
2.指針的運(yùn)算小結(jié)
(1)指針變量的賦值
int a;
int *p
p=&a;
將變量a的地址賦給p
int a[3]={1,2,3};
int *p;
p=a;
將數(shù)組首元素的地址賦給指針p
int a[3]={1,2,3};
int *p;
p=&a[2];
將數(shù)組中的元素的地址賦給指針p
int main(){
int f(int z);
int (*p)(int z);
p=f;
p(5);
}
int f(int z ){
cout<<z<<endl;
}
f為已經(jīng)定義的函數(shù),將f的入口地址賦給p
int a=3;
int *p1=&a;
int *p2=p1;
p1和p2是同類型的指針,將p1的值賦給p2
(2)指針變量賦空值
指針變量可以有空值,即該指針變量不指向任何變量,可以這樣表示:
p=NULL;
實(shí)際上NULL代表整數(shù)0,也就是使p指向地址為0的單元。這樣可以使指針不指向任何有效的單元。
實(shí)際上系統(tǒng)已經(jīng)定義了NULL:
#define NULL 0
C++中在iostream頭文件中就包括了以上的NULL定義,NULL使一個(gè)符號(hào)常量。
在C-free編輯器中運(yùn)行:
#include<iostream>
using namespace std;
int main(){
cout<<NULL;
cout<<endl;
}
應(yīng)注意,p的值等于NULL和p未被賦是兩個(gè)概念。前者是有值得(值為0),不指向任何變量,后者雖未對(duì)p賦值但并不等于p無(wú)值,只是它的值是一個(gè)無(wú)法預(yù)料的值,也就是p可能指向某一個(gè)未指定的單元。這種情況是非常危險(xiǎn)的。因此,在飲用變量之前一定要對(duì)其進(jìn)行賦值。
任何指針變量或地址都可以與NULL做相等或者不等的比較:
if(p==NULL)p=p1;
上面的語(yǔ)句還可以寫成:
if(!p)p=p1;
還應(yīng)注意
int *p=NULL;和int *p;*p=NULL;的區(qū)別:
int *p=NULL是定義了一個(gè)指向整形變量的指針,并且對(duì)該指針進(jìn)行了初始化操作,賦初始值為NULL;
而int *p;是定義了一個(gè)指向整形變量的指針,因?yàn)闆]有對(duì)該指針進(jìn)行初始化,所以它可能指向任何一個(gè)值,因此可能指向一個(gè)非法的值,例如系統(tǒng)內(nèi)存中的變量。
然后*p =NULL;是使p所指向的變量的值為0,因?yàn)閜所指向的值是不確定的,所以該操作是十分危險(xiǎn)的。
(3)指針變量的賦值應(yīng)該注意的問題
我們知道基類型相同的不同的指針變量之間可以賦值。
不同的的基類型的變量之間是不可以進(jìn)行賦值的。
運(yùn)行代碼:
#include<iostream>
using namespace std;
int main(){
<span style="white-space:pre"> </span>int *p1,i=5;
<span style="white-space:pre"> </span>double *p2 ,j=2.5;
<span style="white-space:pre"> </span>p1=&i;
<span style="white-space:pre"> </span>p2=&j;
p1=p2;
cout<<*p1<<endl;
return 0;
}
編輯器提示:
可以通過強(qiáng)制類型轉(zhuǎn)化實(shí)現(xiàn)上述賦值:
#include<iostream>
using namespace std;
int main(){
int *p1,i=5;
double *p2 ,j=2.5;
p1=&i;
cout<<*p1<<endl;
p2=&j;
cout<<*p2<<endl;
p1=(int *)p2;
cout<<*p1<<endl;
return 0;
}
雖然,上述操作不再報(bào)錯(cuò),但是指針的強(qiáng)制類型轉(zhuǎn)發(fā)生了數(shù)據(jù)截?cái)?,所以仍然得不到理想的結(jié)果:
關(guān)于指針的強(qiáng)制類型轉(zhuǎn)換
(4)指針變量加/減一個(gè)整數(shù)
例如:
p++;
p--;
p+i;
p-1;
p+=i;
p-=i;
C++規(guī)定,一個(gè)指針變量加/減一個(gè)整數(shù)是將該指針變量的原值(原來(lái)指向的地址)和它指向的變量所占用的內(nèi)存單元字節(jié)數(shù)相加或者相減。
如p+i;代表這樣的地址計(jì)算:p+i*d,d是p所指向的變量單元所占用的字節(jié)數(shù)。這樣才能保證p+i指向p下面的第i個(gè)元素。
(5)兩個(gè)指針變量相減
如果兩個(gè)指針指向的同一個(gè)數(shù)組中的元素,則兩個(gè)指針變量之差是兩個(gè)指針變來(lái)那個(gè)之間的元素的個(gè)數(shù)。
#include<iostream>
using namespace std;
int main(){
int a[10]={1,2,3,4,5,6,7,8,9,10};
int *p1=&a[3];
int *p2=&a[5];
cout<<(p2-p1)<<endl;
cout<<(p1-p2)<<endl;
return 0;
}
運(yùn)行結(jié)果:
(6)兩個(gè)指針變量比較
若兩個(gè)指針指向同一個(gè)數(shù)組的元素,則可以進(jìn)行比較大小。指向前面元素的指針變量小于指向后面元素的指針變量。
#include<iostream>
using namespace std;
int main(){
int a[10]={1,2,3,4,5,6,7,8,9,10};
int *p1=&a[3];
int *p2=&a[5];
if(p1<p2){
cout<<"p1<p2"<<endl;
}else{
cout<<"p1>=p2"<<endl;
}
return 0;
}
結(jié)果輸出:
還可以利用這個(gè)性質(zhì),輸出數(shù)組中的所有的元素:
#include<iostream>
using namespace std;
int main(){
int a[10]={1,2,3,4,5,6,7,8,9,10};
int *p=a;
while(p<a+10){
cout<<*p<<endl;
p++;
}
return 0;
}
輸出結(jié)果:
上一篇:深入解析C語(yǔ)言中typedef的四個(gè)用途
欄 目:C語(yǔ)言
本文標(biāo)題:基于指針的數(shù)據(jù)類型與指針運(yùn)算小結(jié)
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/4208.html
您可能感興趣的文章
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)式函數(shù)庫(kù)
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)數(shù)怎么表達(dá)
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎么打出三角函數(shù)的值
- 01-10c語(yǔ)言求1+2+...+n的解決方法
- 01-10求子數(shù)組最大和的解決方法詳解
- 01-10深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法
- 01-10深入二叉樹兩個(gè)結(jié)點(diǎn)的最低共同父結(jié)點(diǎn)的詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)- 解析最少換車次數(shù)的問題詳解
- 01-10c語(yǔ)言 跳臺(tái)階問題的解決方法
- 01-10如何判斷一個(gè)數(shù)是否為2的冪次方?若是,并判斷出來(lái)是多少次方


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10delphi制作wav文件的方法
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文