欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于指針的數(shù)據(jù)類型與指針運(yùn)算小結(jié)

 更新時(shí)間:2013年09月02日 10:25:40   作者:  
以下是對(duì)指針的數(shù)據(jù)類型與指針運(yùn)算進(jìn)行了詳細(xì)的總結(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)指針變量的賦值
復(fù)制代碼 代碼如下:

int a;
int *p
p=&a;

將變量a的地址賦給p
復(fù)制代碼 代碼如下:

int a[3]={1,2,3};
int *p;
p=a;

將數(shù)組首元素的地址賦給指針p
復(fù)制代碼 代碼如下:

int a[3]={1,2,3};
int *p;
p=&a[2];

將數(shù)組中的元素的地址賦給指針p
復(fù)制代碼 代碼如下:

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
復(fù)制代碼 代碼如下:

int a=3;
int *p1=&a;
int *p2=p1;

p1和p2是同類型的指針,將p1的值賦給p2

(2)指針變量賦空值
指針變量可以有空值,即該指針變量不指向任何變量,可以這樣表示:

復(fù)制代碼 代碼如下:

p=NULL;

實(shí)際上NULL代表整數(shù)0,也就是使p指向地址為0的單元。這樣可以使指針不指向任何有效的單元。
實(shí)際上系統(tǒng)已經(jīng)定義了NULL:
復(fù)制代碼 代碼如下:

#define NULL 0

C++中在iostream頭文件中就包括了以上的NULL定義,NULL使一個(gè)符號(hào)常量。
在C-free編輯器中運(yùn)行:
復(fù)制代碼 代碼如下:

#include<iostream>
using namespace std;
int main(){
 cout<<NULL;
 cout<<endl;
}




應(yīng)注意,p的值等于NULL和p未被賦是兩個(gè)概念。前者是有值得(值為0),不指向任何變量,后者雖未對(duì)p賦值但并不等于p無值,只是它的值是一個(gè)無法預(yù)料的值,也就是p可能指向某一個(gè)未指定的單元。這種情況是非常危險(xiǎn)的。因此,在飲用變量之前一定要對(duì)其進(jìn)行賦值。

任何指針變量或地址都可以與NULL做相等或者不等的比較:

復(fù)制代碼 代碼如下:

if(p==NULL)p=p1;

上面的語句還可以寫成:
復(fù)制代碼 代碼如下:

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)行代碼:

復(fù)制代碼 代碼如下:

#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)上述賦值:

復(fù)制代碼 代碼如下:

#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)啵匀匀坏貌坏嚼硐氲慕Y(jié)果:



關(guān)于指針的強(qiáng)制類型轉(zhuǎn)換

(4)指針變量加/減一個(gè)整數(shù)

例如:

復(fù)制代碼 代碼如下:

p++;
p--;
p+i;
p-1;
p+=i;
p-=i;

C++規(guī)定,一個(gè)指針變量加/減一個(gè)整數(shù)是將該指針變量的原值(原來指向的地址)和它指向的變量所占用的內(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è)指針變來那個(gè)之間的元素的個(gè)數(shù)。

復(fù)制代碼 代碼如下:

#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)行比較大小。指向前面元素的指針變量小于指向后面元素的指針變量。
復(fù)制代碼 代碼如下:

#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ù)組中的所有的元素:

復(fù)制代碼 代碼如下:

#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é)果:

相關(guān)文章

  • C語言簡(jiǎn)單實(shí)現(xiàn)銀行ATM存取款功能

    C語言簡(jiǎn)單實(shí)現(xiàn)銀行ATM存取款功能

    這個(gè)是大一時(shí)期寫的。大四的時(shí)候整理了一下(本人C語言學(xué)的也不太好)??隙ê芏嗖蛔愫痛嬖诼┒吹牡胤?、僅供借鑒、僅供借鑒,代碼中有大量注釋,新手看起來也沒有困難
    2021-11-11
  • Cocos2d-x UI開發(fā)之場(chǎng)景切換代碼實(shí)例

    Cocos2d-x UI開發(fā)之場(chǎng)景切換代碼實(shí)例

    這篇文章主要介紹了Cocos2d-x UI開發(fā)之場(chǎng)景切換代碼實(shí)例,cocos2d-x中的場(chǎng)景切換是通過導(dǎo)演類調(diào)用相應(yīng)的方法完成的,本文通過代碼和詳細(xì)注釋來說明,需要的朋友可以參考下
    2014-09-09
  • 深入理解C++11:探索lambda函數(shù)的奧秘

    深入理解C++11:探索lambda函數(shù)的奧秘

    聚焦于C++11,讓我們一起探索lambda函數(shù)的奧秘,本指南將帶您深入了解這個(gè)強(qiáng)大的編程工具,讓您在編程世界中如虎添翼,無論您是初學(xué)者還是有經(jīng)驗(yàn)的開發(fā)者,本指南都將為您帶來全新的視角和實(shí)用的技巧,需要的朋友可以參考下
    2024-01-01
  • C++類的靜態(tài)成員變量與靜態(tài)成員函數(shù)詳解

    C++類的靜態(tài)成員變量與靜態(tài)成員函數(shù)詳解

    下面小編就為大家?guī)硪黄狢++類的靜態(tài)成員變量與靜態(tài)成員函數(shù)的文章。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2021-11-11
  • c語言實(shí)現(xiàn)向上取整計(jì)算方法

    c語言實(shí)現(xiàn)向上取整計(jì)算方法

    這篇文章主要介紹了c語言實(shí)現(xiàn)向上取整計(jì)算方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 詳解C語言內(nèi)核字符串轉(zhuǎn)換方法

    詳解C語言內(nèi)核字符串轉(zhuǎn)換方法

    在內(nèi)核開發(fā)模式下,初始化字符串也需要調(diào)用專用的初始化函數(shù),如下分別初始化ANSI和UNCODE字符串,本文我們就來看看代碼是如何實(shí)現(xiàn)的
    2022-09-09
  • QT實(shí)現(xiàn)簡(jiǎn)單打地鼠游戲

    QT實(shí)現(xiàn)簡(jiǎn)單打地鼠游戲

    這篇文章主要為大家詳細(xì)介紹了QT實(shí)現(xiàn)簡(jiǎn)單打地鼠游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C++超詳細(xì)實(shí)現(xiàn)堆和堆排序過像

    C++超詳細(xì)實(shí)現(xiàn)堆和堆排序過像

    堆是計(jì)算機(jī)科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱,通常是一個(gè)可以被看做一棵完全二叉樹的數(shù)組對(duì)象。而堆排序是利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。本文將通過圖片詳細(xì)介紹堆排序,需要的可以參考一下
    2022-06-06
  • C++學(xué)習(xí)之如何進(jìn)行內(nèi)存資源管理

    C++學(xué)習(xí)之如何進(jìn)行內(nèi)存資源管理

    與java、golang等自帶垃圾回收機(jī)制的語言不同,C++并不會(huì)自動(dòng)回收內(nèi)存,這往往會(huì)導(dǎo)致內(nèi)存泄漏和內(nèi)存溢出等問題,所以掌握C++中的內(nèi)存管理技巧和工具是非常重要的,本文就來和大家詳細(xì)講講
    2023-05-05
  • C語言實(shí)現(xiàn)萬年歷小功能

    C語言實(shí)現(xiàn)萬年歷小功能

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)萬年歷小功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03

最新評(píng)論