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

c語(yǔ)言中數(shù)組名a和&a詳細(xì)介紹

 更新時(shí)間:2013年08月22日 08:47:41   作者:  
其實(shí)這兩個(gè)東西挺難理解的,應(yīng)該也沒(méi)有那么重要,了解一下好了,主要還是要多多理解數(shù)組指針的運(yùn)算

最近又把學(xué)習(xí)c語(yǔ)言提上日程上來(lái)了~~~先把我打算看的書都寫下來(lái)吧,<C語(yǔ)言深度剖析>,<c和指針>系類,<c語(yǔ)言陷阱和缺陷>

先說(shuō)說(shuō)a和&a的區(qū)別(有三點(diǎn),三個(gè)方向):
1.是a和&a的本質(zhì),都是什么類型的。
2.從2維數(shù)組的角度看。
3.從指針運(yùn)算的角度看。

聲明:雖然數(shù)組名不是指針,但是用的很像指針,我們暫且把它叫做一個(gè)指針吧。

第一個(gè)問(wèn)題:
int a[10];  a ,&a和&a[0] 都是分別是什么?先說(shuō)明a ,&a和&a[0]三個(gè)值是的相等哈。

a叫做數(shù)組名,是數(shù)組首元素的地址,也就是&a[0]的值。像是一個(gè)指針類型,是一個(gè)int型的指針類型,int *,先理解成指針吧。

&a這才是一個(gè)真正的指針,是一個(gè)數(shù)組指針。是數(shù)組的地址。

切記:&a不是指向指針的指針,因?yàn)?amp;a和a的值相等,但是*&a和*a的值不相等。*&a和a的值一樣,說(shuō)明*&a僅僅是對(duì)這個(gè)數(shù)組指針進(jìn)行了取值,取得的是數(shù)組的值,即數(shù)組首元素的地址,而不是對(duì)&a這個(gè)地址進(jìn)行了取值。這個(gè)應(yīng)該是c語(yǔ)言中針對(duì)數(shù)組指針運(yùn)算的規(guī)定。 

這里的數(shù)組指針&a取值之后,變成了a,是a,不是*a,變成了這個(gè)數(shù)組的數(shù)組名,或者說(shuō)是數(shù)組首元素的地址。

我做了如下實(shí)驗(yàn):

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

#include<stdio.h>
 int main()
 {
         int a[5]={1,2,3,4,5};
         printf("a=%x\n",a);
         printf("&a=%x\n",&a);
         printf("*(int*)&a=%x\n",(*((int *)(&a))));
         printf("*&a=%x\n",(*(*(&a))));
         printf("&a[0]=%x\n",&a[0]);
         printf("*&a[0]=%x\n",*(&a[0]));
         return 0;
 }


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

printf("*(int*)&a=%x\n",(*((int *)(&a))));

這句沒(méi)有像常規(guī)的一樣對(duì)&a進(jìn)行取值,而是強(qiáng)制類型轉(zhuǎn)換了一下,可見(jiàn)這個(gè)不是一個(gè)指向指針的指針。

第二個(gè)問(wèn)題:
二維數(shù)組中的利用指針來(lái)遍歷的方式,也不是一個(gè)指向指針的指針(2級(jí)指針) ,這句printf("%d\n", *(*(a+i) + j));  *(a+i)也就是將數(shù)組指針取值獲得數(shù)組的首元素地址,常常的誤區(qū)就是數(shù)組指針的取值運(yùn)算和普通的指針取值運(yùn)算不一樣。數(shù)組指針取值運(yùn)算類似一個(gè)強(qiáng)制類型轉(zhuǎn)換的過(guò)程。    

注意:二維數(shù)組的數(shù)組名a,是第一個(gè)一維數(shù)組的數(shù)組指針,*a就是第一個(gè)一維數(shù)組的數(shù)組名。也可以直接用tpye *強(qiáng)制類型轉(zhuǎn)換。

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

 #include <stdio.h>

 int main(int argc, char* argv[], char* env[])
 {
    int a[3][3] = {{0, 1, 2}, {3, 4, 5}, {6, 7, 8}};
    int i = 0;
    int j = 0;

    for(i=0; i<3; i++)
    {
         for(j=0; j<3; j++)
         {
           //  printf("%d\n", *((int *)(a+i) + j));
                  printf("%d\n", *(*(a+i) + j));
         }
     }

其實(shí)這兩個(gè)東西挺難理解的,應(yīng)該也沒(méi)有那么重要,了解一下好了,主要還是要多多理解數(shù)組指針的運(yùn)算。因?yàn)槲铱戳撕枚辔恼露际峭ㄟ^(guò)對(duì)&a和a的運(yùn)算角度來(lái)說(shuō)明兩者不是一個(gè)東西的。

您可能感興趣的文章:

相關(guān)文章

  • ubuntu修改gcc版本的操作方法

    ubuntu修改gcc版本的操作方法

    今天小編就為大家分享一篇ubuntu修改gcc版本的操作方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-12-12
  • C++超詳細(xì)分析單鏈表的實(shí)現(xiàn)與常見(jiàn)接口

    C++超詳細(xì)分析單鏈表的實(shí)現(xiàn)與常見(jiàn)接口

    鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的,本章帶你分析單鏈表的實(shí)現(xiàn)與常見(jiàn)接口
    2022-03-03
  • C++中求組合數(shù)的各種方法總結(jié)詳解

    C++中求組合數(shù)的各種方法總結(jié)詳解

    本篇文章是對(duì)C++中的求組合數(shù)的各種方法進(jìn)行了詳細(xì)的介紹。需要的朋友參考下
    2013-05-05
  • C語(yǔ)言字符串的模式匹配之BF與KMP

    C語(yǔ)言字符串的模式匹配之BF與KMP

    這篇文章記錄一下串里面的模式匹配,模式匹配,顧名思義就是給定一個(gè)被匹配的字符串,然后用一個(gè)字符串模式(模型)去匹配上面說(shuō)的字符串,看后者是否在前者里面出現(xiàn)。常用的有2種算法可以實(shí)現(xiàn),下面我們來(lái)具體探討下
    2021-09-09
  • C++11中union的使用方法示例

    C++11中union的使用方法示例

    這篇文章主要給大家介紹了關(guān)于C++11中union的使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • C語(yǔ)言實(shí)現(xiàn)貪吃蛇游戲(單人版)

    C語(yǔ)言實(shí)現(xiàn)貪吃蛇游戲(單人版)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)貪吃蛇游戲單人版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • C語(yǔ)言 數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組模擬實(shí)現(xiàn)順序表流程詳解

    C語(yǔ)言 數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組模擬實(shí)現(xiàn)順序表流程詳解

    順序表,全名順序存儲(chǔ)結(jié)構(gòu),是線性表的一種,線性表用于存儲(chǔ)邏輯關(guān)系為“一對(duì)一”的數(shù)據(jù),順序表自然也不例外,不僅如此,順序表對(duì)數(shù)據(jù)的物理存儲(chǔ)結(jié)構(gòu)也有要求,跟隨下文來(lái)具體了解吧
    2021-11-11
  • C++中map容器的具體使用

    C++中map容器的具體使用

    本文主要介紹了C++中map容器的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Qt實(shí)現(xiàn)拖拽功能圖文教程(支持拖放文件、拖放操作)

    Qt實(shí)現(xiàn)拖拽功能圖文教程(支持拖放文件、拖放操作)

    這篇文章主要給大家介紹了關(guān)于Qt實(shí)現(xiàn)拖拽功能(支持拖放文件、拖放操作)的相關(guān)資料,Qt是一款多平臺(tái)的C++應(yīng)用程序開(kāi)發(fā)框架,它的獨(dú)特之處在于可以快速開(kāi)發(fā)出拖放式的開(kāi)發(fā)桌面程序,需要的朋友可以參考下
    2023-11-11
  • C語(yǔ)言中帶頭雙向循環(huán)鏈表基本操作的實(shí)現(xiàn)詳解

    C語(yǔ)言中帶頭雙向循環(huán)鏈表基本操作的實(shí)現(xiàn)詳解

    無(wú)頭單向非循環(huán)鏈表結(jié)構(gòu)簡(jiǎn)單,一般不會(huì)單獨(dú)用來(lái)存數(shù)據(jù)。而帶頭雙向循環(huán)鏈表的結(jié)構(gòu)較為復(fù)雜,一般用在單獨(dú)存儲(chǔ)數(shù)據(jù)。本文將介紹帶頭雙向循環(huán)鏈表的基本操作,需要的可以參考一下
    2022-11-11

最新評(píng)論