code.club

 找回密碼
 立即註冊
搜索
查看: 7088|回復: 0
打印 上一主題 下一主題

用指標求位址的觀念問題?

[複製鏈接]
跳轉到指定樓層
樓主
發表於 2014-6-29 22:35:01 | 只看該作者 回帖獎勵 |正序瀏覽 |閱讀模式
本帖最後由 return 於 2014-6-30 16:08 編輯

遇到一些可能是觀念上的問題想請教一下先進:

#include <stdio.h>
#include <conio.h>

int main(void)
{
        int a[3][2]={11,22,33,44,55,66};
printf("%p\n",a[0]);//前面四個無論有沒有加&
printf("%p\n",&a[0]);//求出來的結果是一樣的。
printf("%p\n",&a);//
printf("%p\n",&a[0][0]);//
printf("%p\n",a[0][0]);//如果完整列出陣列的二個元素號碼,不加&則無法求得位址?
printf("%p\n",&a[1][0]);//為何這一個等於下一個?
printf("%p\n",a+1);//a+1不是應該是a[0][0]的下一個是a[0][1]嗎?怎會變成a[1][0]?
printf("%p\n",&a[0][1]);//
printf("%p\n",a[0]+1);//a[0]和a雖然都指向a[0][0],但a+1和a[0]+1的結果卻不同,a+1指向a[1][0],而a[0]+1則指向a[0][1]。
        return 0;
}



000000000022FE40
000000000022FE40
000000000022FE40---->這四個都是求得a[0][0]也就是a或者a[0]第位址。
000000000022FE40

000000000000000B----->但如果用a[0][0]前面不加&則不行?

000000000022FE48------>&a[1][0]
000000000022FE48------>a+1
000000000022FE44------>&a[1][0]---->這不是排第二的元素嗎?怎麼a+1會跑到第三個的a[1][0]呢?

C語言中的指標實在花招很多,何時要有&何時不用也可以,真的很複雜。
回復

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即註冊

本版積分規則

小黑屋|手機版|Archiver|code.club  

GMT+8, 2024-11-22 01:43 , Processed in 0.079736 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回復 返回頂部 返回列表