陣列指標(也稱行指標)
定義 int (*p)[10];
()優先順序高,首先說明p是一個指標,指向一個整型的一維陣列,這個一維陣列的長度是10,也可以說是p的步長。也就是說執行p+1時,p要跨過10個整型資料的長度。
例:int (*p)[4]; //該語句是定義一個數組指標,指向含4個元素的一維陣列。所以陣列指標也稱指向一維陣列的指標,亦稱行指標。
指標陣列定義 int *p[n];[]優先順序高,先與p結合成為一個數組,再由int*說明這是一個整型指標陣列,它有n個指標型別的陣列元素。這裡執行p+1時,則p指向下一個陣列元素,這樣賦值是錯誤的:p=a;因為p是個不可知的表示,只存在p[0]、p[1]、p[2]...p[n-1],而且它們分別是指標變數可以用來存放變數地址。但可以這樣 *p=a; 這裡*p表示指標陣列第一個元素的值,a的首地址的值。如要將二維陣列賦給一指標陣列:int *p[3];int a[3][4];p++; //該語句表示p陣列指向下一個陣列元素。注:此陣列每一個元素都是一個指標for(i=0;i<3;i++)p[i]=a[i]這裡int *p[3] 表示一個一維陣列記憶體放著三個指標變數,分別是p[0]、p[1]、p[2]所以要分別賦值。
這樣兩者的區別就豁然開朗了,陣列指標只是一個指標變數,似乎是C語言裡專門用來指向二維陣列的,它佔有記憶體中一個指標的儲存空間。指標陣列是多個指標變數,以陣列形式存在記憶體當中,佔有多個指標的儲存空間。
C語言30天核心突破
陣列指標(也稱行指標)
定義 int (*p)[10];
()優先順序高,首先說明p是一個指標,指向一個整型的一維陣列,這個一維陣列的長度是10,也可以說是p的步長。也就是說執行p+1時,p要跨過10個整型資料的長度。
例:int (*p)[4]; //該語句是定義一個數組指標,指向含4個元素的一維陣列。所以陣列指標也稱指向一維陣列的指標,亦稱行指標。
指標陣列定義 int *p[n];[]優先順序高,先與p結合成為一個數組,再由int*說明這是一個整型指標陣列,它有n個指標型別的陣列元素。這裡執行p+1時,則p指向下一個陣列元素,這樣賦值是錯誤的:p=a;因為p是個不可知的表示,只存在p[0]、p[1]、p[2]...p[n-1],而且它們分別是指標變數可以用來存放變數地址。但可以這樣 *p=a; 這裡*p表示指標陣列第一個元素的值,a的首地址的值。如要將二維陣列賦給一指標陣列:int *p[3];int a[3][4];p++; //該語句表示p陣列指向下一個陣列元素。注:此陣列每一個元素都是一個指標for(i=0;i<3;i++)p[i]=a[i]這裡int *p[3] 表示一個一維陣列記憶體放著三個指標變數,分別是p[0]、p[1]、p[2]所以要分別賦值。
這樣兩者的區別就豁然開朗了,陣列指標只是一個指標變數,似乎是C語言裡專門用來指向二維陣列的,它佔有記憶體中一個指標的儲存空間。指標陣列是多個指標變數,以陣列形式存在記憶體當中,佔有多個指標的儲存空間。
C語言30天核心突破