1. 指標與陣列的宣告
舉個慄紙
int a[5]
=;//建立乙個int型,長度為5的陣列。 並初始化為
int*p = a;
//建立乙個指向陣列a的指標
一下問題的輸出結果?
printf
("%d"
,a[0])
;printf
("%d"
,&a[0]
);printf
("%d"
,&a)
;printf
("%d"
,a);
printf
("%d"
,p);
答案是這樣的
printf("%d",a[0]);
----> 0
printf("%d",&a[0]);
----> -272632320(這是陣列在記憶體中的位址,每個人測試的時候都會得到乙個不同的位址)
printf("%d",&a);
----> -272632320
printf("%d",a);
----> -272632320
printf("%d",p);
----> -272632320
精簡版總結:
複雜版總結(這段看不懂就不用看啦):
2. 指標與陣列的訪問還是這個慄紙
int a[5]
=;//建立乙個int型,長度為5的陣列。 並初始化為
int*p = a;
//建立乙個指向陣列a的指標
又多了幾個問題。。
printf
("%d"
,&a[0]
); 或者printf
("%d"
,a);
printf
("%d"
,a+1);
printf
("%d"
,&a+1)
;printf
("%d"
,*p)
;printf
("%d",*
(p+1))
;
答案是這樣的
printf("%d",&a[0]); 或者printf("%d",a);
----> -272632320
printf("%d",a+1);
----> -272632316(比a[0]的位址大4)
printf("%d",&a+1);
----> -272632300(比a[0]的位址大20,5個4)
printf("%d",*p);
----> 0
printf("%d",*(p+1));
----> 2
精簡版總結:
3. 指標作為函式的形參
指標與陣列,指標陣列 陣列指標
int a 10 print n a p,a p a,a print n a 1 p,a 1 p a 1,a 1 a做乙個指標,步長為4,指向乙個元素,a做乙個指標,步長為40,指向乙個維陣列 int b 3 4 print n b p,b p,b p b,b,b print n b 1 p,b 1...
指標陣列與陣列指標
1.指標陣列 指標陣列中每乙個元素都是乙個指標,也既是存放字串的首位址。所以指標陣列適合處理若干個長度不等的字串。定義的一般形式為 型別說明符 指標陣列名 陣列長度 例如 int p 3 宣告乙個陣列,指標陣列p,由3個int型別指標變數元素組成 從運算子的優先順序分析,由於 的優先順序大於 所以p...
指標陣列與陣列指標
呵呵,實在是厭倦了繞口的解釋。指標陣列,故名思義,就是指標的陣列,陣列的元素是指標 陣列指標,同樣,就是直想陣列的指標。簡單舉例說明 int p 2 首先宣告了乙個陣列,陣列的元素是int型的指標。int p 2 宣告了乙個指標,指向了乙個有兩個int元素的陣列。其實這兩種寫法主要是因為運算子的優先...