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

C++指針數(shù)組、數(shù)組指針、數(shù)組名及二維數(shù)組技巧匯總

 更新時間:2014年08月23日 09:42:33   投稿:shichen2014  
這篇文章主要介紹了C++指針數(shù)組、數(shù)組指針、數(shù)組名及二維數(shù)組技巧匯總,對于深入理解C++數(shù)組與指針來說非常重要,需要的朋友可以參考下

本文較為詳細(xì)的分析了關(guān)于理解C++指針數(shù)組,數(shù)組指針,數(shù)組名,二維數(shù)組的一些技巧。是比較重要的概念,相信對于大家的C++程序設(shè)計有一定的幫助作用。

一、關(guān)于數(shù)組名

假設(shè)有數(shù)組:

int a[3] = {1, 2, 3}

1.數(shù)組名代表數(shù)組第一個元素的地址,注意,不是數(shù)組地址(雖然值相等),是數(shù)組第一個元素地址,a 等同于 &a[0];

a+1是第二個元素的地址。比第一個元素地址a(或者&a[0])超出了一個整型指針的大小,在這里是4個字節(jié)(byte)

cout << a << endl;//會輸出數(shù)組第一個元素地址。

2.取址符號&.

&a是數(shù)組的地址,注意是數(shù)組的地址,表示數(shù)組這個整體的地址。不是數(shù)組第一個元素的地址(雖然他們的值相同)

&a+1比數(shù)組的地址&a超出了一個數(shù)組的地址大小,在這里是3*4個字節(jié)

int * p = &a;這條語句是不成立的。左邊指針變量p時指向整型的指針,而右邊是數(shù)組(類型是數(shù)組)的地址,不是數(shù)組元素(類型是整型)的地址,所以不能賦值。
應(yīng)該賦值給數(shù)組指針(下面會講到)。

關(guān)于數(shù)組名,切記以上兩點。

二、關(guān)于指針數(shù)組

1.定義

指針數(shù)組,就是存放指針的數(shù)組,數(shù)組里的元素是指針(對比于整型數(shù)組,整型數(shù)組就是存放整型的數(shù)組,數(shù)組里的元素是整型)

int *ptr[3];如何理解?按照運算符優(yōu)先級,[]優(yōu)先級較大,所以ptr先與[3]結(jié)合,表示ptr是一個數(shù)組,必然要明確數(shù)組的元素類型,所以數(shù)組里的元素類型是整型指針(int*),數(shù)組的大小不一定需要(定義數(shù)組時可以根據(jù)初始化的元素個數(shù)確定)

ptr[0]就是數(shù)組的第零個元素,它是一個整型指針。

示例如下:

int a[3] = {1, 2, 3};
int x = 5;
ptr[0] = &x;
ptr[1] = &a[2];

2.如何使用?

像一般指針一樣使用。*ptr[0]就是第零個元素(一個指針)所指向元素的值,這里是 5。

三、關(guān)于數(shù)組指針

1.定義

數(shù)組指針,就是指向數(shù)組的指針,它是一個指針,指向一個數(shù)組(對比于整型指針,就是指向整型的指針,它是一個指針,指向一個整型)

int (*ptr)[3]; 如何理解?先看小括號里面,*ptr說明ptr是一個指針,然后跟[]結(jié)合表明這個指針指向一個數(shù)組,數(shù)組的元素是int

int a[3] = {1, 2, 3};
int(*ptr)[3] = a;//這條語句不成立。

右邊a是數(shù)組名,還記得上面說的嗎,數(shù)組名代表數(shù)組第一個元素的地址,就是&a[0],數(shù)組名的類型相當(dāng)于整型指針(不知道事實上是不是)int *,因為它指向了第一個元素,第一個元素是int

左邊ptr的類型是int(*)[],是數(shù)組指針,指向數(shù)組的指針,不是指向整型的指針,不能賦值。

int a[3] = {1, 2, 3};
int (*ptr)[3] = &a;//正確。

因為a是一個數(shù)組,&a就是數(shù)組的地址,還記得上面說的嗎?

2.如何使用?

int a[3] = {1, 2, 3};
int (*ptr)[3] = &a;

cout << (*ptr)[0] << endl;  //輸出1
cout << (*ptr)[1] << endl;  //輸出2

這里有一點難以理解。不防對比一下一下代碼。

int a[3] = {1, 2, 3};
int x = 5;
int * p = &x;
cout << *p << endl;  //輸出5

p是一個指向整型的指針,*p就是所指向的變量(整型x)的值。同理ptr是指向數(shù)組的指針,*ptr就是所指向的變量(數(shù)組a)的值。(*ptr)[0]就是數(shù)組的第零個元素。

四、關(guān)于二維數(shù)組

1.二維數(shù)組是一個數(shù)組,它的元素是一維數(shù)組。謹(jǐn)記這一點,然后把上面的套進(jìn)來就行了。

int a[3][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};

數(shù)組名

a是數(shù)組第一個(或者說第零個更好)元素的地址,第一個元素是一維數(shù)組,a[0] ------> {1, 2, 3}。a+1是第二個元素的地址,就是第二個一維數(shù)組的地址,超出了3*4個字節(jié)

&a是數(shù)組的地址,&a+1 就是超出了一個二維數(shù)組的大小,超出了3 * 4 * 3 個字節(jié)。

數(shù)組指針

int (*ptr)[3] = a; //正確。

因為a表示第一個元素的地址,第一個元素是一個一維數(shù)組,所以a表示一個一維數(shù)組的地址,一個數(shù)組的地址賦值給數(shù)組指針,成立。

五、總結(jié):

1.數(shù)組名表示數(shù)組的第一個元素的地址。

2.&a(a是一個數(shù)組)是數(shù)組的地址。

3.指針數(shù)組是一個數(shù)組,它的元素是指針。

4.數(shù)組指針是一個指針,它指向一個數(shù)組。

5.二維數(shù)組的元素是一維數(shù)組。

相關(guān)文章

  • C語言簡明講解隊列的實現(xiàn)方法

    C語言簡明講解隊列的實現(xiàn)方法

    隊列(Queue)與棧一樣,是一種線性存儲結(jié)構(gòu),它具有如下特點:隊列中的數(shù)據(jù)元素遵循“先進(jìn)先出”(First?In?First?Out)的原則,簡稱FIFO結(jié)構(gòu)。在隊尾添加元素,在隊頭刪除元素
    2022-04-04
  • C++ Boost Bimap示例詳細(xì)講解

    C++ Boost Bimap示例詳細(xì)講解

    Boost是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱
    2022-11-11
  • C語言編寫掃雷小程序

    C語言編寫掃雷小程序

    這篇文章主要為大家詳細(xì)介紹了C語言編寫掃雷小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • C++11新特性之列表初始化的具體使用

    C++11新特性之列表初始化的具體使用

    在我們實際編程中,我們經(jīng)常會碰到變量初始化的問題,本文主要介紹了C++11新特性之列表初始化的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C語言 動態(tài)內(nèi)存開辟常見問題解決與分析流程

    C語言 動態(tài)內(nèi)存開辟常見問題解決與分析流程

    動態(tài)內(nèi)存是相對靜態(tài)內(nèi)存而言的。所謂動態(tài)和靜態(tài)就是指內(nèi)存的分配方式。動態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存
    2022-03-03
  • C++最優(yōu)二叉樹哈夫曼樹算法解析

    C++最優(yōu)二叉樹哈夫曼樹算法解析

    這篇文章主要介紹了C++最優(yōu)二叉樹哈夫曼樹算法解析,哈夫曼樹又稱最優(yōu)二叉樹,是一種帶權(quán)路徑長度最短的二叉樹,所謂樹的帶權(quán)路徑長度,就是樹中所有的葉結(jié)點的權(quán)值乘上其到根結(jié)點的路徑長度,需要的朋友可以參考下
    2023-08-08
  • 使用c++實現(xiàn)異或加密的代碼示例

    使用c++實現(xiàn)異或加密的代碼示例

    這篇文章主要為大家介紹了c++實現(xiàn)異或加密的代碼示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • C++實現(xiàn)簡單職工信息管理系統(tǒng)

    C++實現(xiàn)簡單職工信息管理系統(tǒng)

    本文給大家分享的是使用C++實現(xiàn)簡單的職工信息管理系統(tǒng)的代碼,本系統(tǒng)采用了面向?qū)ο蟮某绦蛟O(shè)計方法,所有的方法均以類為基礎(chǔ),感興趣的小伙伴們可以參考一下
    2015-08-08
  • C++線程同步實例分析

    C++線程同步實例分析

    這篇文章主要介紹了C++線程同步實例分析,以實例的形式較為深入的分析了C++的線程同步問題,是一個較為經(jīng)典的線程同步問題,需要的朋友可以參考下
    2014-10-10
  • C語言中四種取整方式,取余/取模運算以及負(fù)數(shù)取模問題詳解

    C語言中四種取整方式,取余/取模運算以及負(fù)數(shù)取模問題詳解

    這篇文章主要介紹了C語言中四種取整方式及負(fù)數(shù)取模問題,包括了算法的分析與改進(jìn),是很多程序設(shè)計競賽中常見的算法,需要的朋友可以參考下
    2021-09-09

最新評論