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

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

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

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

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

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

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

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

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

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

2.取址符號(hào)&.

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

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

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

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

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

1.定義

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

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

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

示例如下:

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

2.如何使用?

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

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

1.定義

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

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

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

右邊a是數(shù)組名,還記得上面說(shuō)的嗎,數(shù)組名代表數(shù)組第一個(gè)元素的地址,就是&a[0],數(shù)組名的類型相當(dāng)于整型指針(不知道事實(shí)上是不是)int *,因?yàn)樗赶蛄说谝粋€(gè)元素,第一個(gè)元素是int

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

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

因?yàn)閍是一個(gè)數(shù)組,&a就是數(shù)組的地址,還記得上面說(shuō)的嗎?

2.如何使用?

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

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

這里有一點(diǎn)難以理解。不防對(duì)比一下一下代碼。

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

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

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

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

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

數(shù)組名

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

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

數(shù)組指針

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

因?yàn)閍表示第一個(gè)元素的地址,第一個(gè)元素是一個(gè)一維數(shù)組,所以a表示一個(gè)一維數(shù)組的地址,一個(gè)數(shù)組的地址賦值給數(shù)組指針,成立。

五、總結(jié):

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

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

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

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

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

相關(guān)文章

  • C語(yǔ)言簡(jiǎn)明講解隊(duì)列的實(shí)現(xiàn)方法

    C語(yǔ)言簡(jiǎn)明講解隊(duì)列的實(shí)現(xiàn)方法

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

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

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

    C語(yǔ)言編寫掃雷小程序

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

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

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

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

    動(dòng)態(tài)內(nèi)存是相對(duì)靜態(tài)內(nèi)存而言的。所謂動(dòng)態(tài)和靜態(tài)就是指內(nèi)存的分配方式。動(dòng)態(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)路徑長(zhǎng)度最短的二叉樹,所謂樹的帶權(quán)路徑長(zhǎng)度,就是樹中所有的葉結(jié)點(diǎn)的權(quán)值乘上其到根結(jié)點(diǎn)的路徑長(zhǎng)度,需要的朋友可以參考下
    2023-08-08
  • 使用c++實(shí)現(xiàn)異或加密的代碼示例

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

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

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

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

    C++線程同步實(shí)例分析

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

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

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

最新評(píng)論