c語(yǔ)言中數(shù)組名a和&a詳細(xì)介紹
最近又把學(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):
#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;
}
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)換。
#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)文章
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-03C語(yǔ)言實(shí)現(xiàn)貪吃蛇游戲(單人版)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)貪吃蛇游戲單人版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06C語(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-11Qt實(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-11C語(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