一維數組名的本質

#include <stdio.h>
#include <string.h>

/* int a[];
 * int (*p)[];   // 定義數組指針
 * int *p2       
 * p = &a;
 * p2 = a;
 * p和p2的區別可從下面程序打印的結果看出
*/

int main(void)
{
    int a[5] = {1, 2, 3, 4, 5};
    int i = 0;
    int (*p)[5];    // 數組指針
    p = &a;
    int *p2 = a;

    printf("sizeof(i)=%d\n", sizeof(i));
    printf("sizeof(a)=%d\n", sizeof(a));

    for (i=0; i<5; i++){
        printf("%d ", (*p)[i]);   // 注意這裏只能使用(*p)來引用
    }
    printf("\n");

    for (i=0; i<5; i++){
        printf("%d ", p2[i]);
    }
    printf("\n");

    printf("p=%x, *p=%x\n", p, *p);
    printf("p+1=%x, *(p+1)=%x\n", p+2, *(p+1));
    printf("a=%x, a+1=%x\n", a, a+1);
    printf("&a=%x, &a+1=%x\n", a, &a+1);
    printf("p2=%x, *p2=%d\n", p2, *p2);
    printf("p2+1=%x, *(p2+1)=%d\n", p2+1, *(p2+1));

/*
 *  sizeof(i)=4                        //   機器上int變量佔4個字節
 *  sizeof(a)=20                       //   數組a佔4*5=20個字節
 *  1 2 3 4 5                          //   通過循環都可以打印出整個數組元素
 *  1 2 3 4 5 
 *  p=cdcf95c0, *p=cdcf95c0            //   p=&a, *p=a 都和數組首元素的地址相等
 *  p+1=cdcf95e8, *(p+1)=cdcf95d4      //   (p+1) - p = 0x28 = 40; *(p+1) - *(p) = 0x14 = 20 從這裏可以看出來 *p表示整個數組的地址
 *
 *  a=cdcf95c0, &a=cdcf95c0            //   (a+1) - a = 0x4 = 4;        所以a代表數組首元素的地址
 *  a+1=cdcf95c4, &a+1=cdcf95d4        //   (&a+1) - &a = 0x14 = 20;    &a代表整個數組的地址
 *                                      
 *  p2=cdcf95c0, *p2=1
 *  p2+1=cdcf95c4, *(p2+1)=2           //   (p2+1) - p2 = 0x4 = 4; 而這裏p2就表示數組首元素的地址
 *
 *  總結: p2 = a 代表數組首元素的地址
 *        *p = &a 代表整個數組的地址
*/  

    return 0;
}

總結: p2 = a 代表數組首元素的地址
p = &a 代表整個數組的地址

發佈了39 篇原創文章 · 獲贊 22 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章