C 指針是一個用數值表示的位址。是以,您可以對指針執行算術運算。可以對指針進行四種算術運算:++、--、+、-。
假設 ptr 是一個指向位址 1000 的整型指針,是一個 32 位的整數,讓我們對該指針執行下列的算術運算:
ptr++
在執行完上述的運算之後,ptr 将指向位置 1004,因為 ptr 每增加一次,它都将指向下一個整數位置,即目前位置往後移 4 位元組。這個運算會在不影響記憶體位置中實際值的情況下,移動指針到下一個記憶體位置。如果 ptr 指向一個位址為 1000 的字元,上面的運算會導緻指針指向位置 1001,因為下一個字元位置是在 1001。
我們概括一下:
指針的每一次遞增,它其實會指向下一個元素的存儲單元。
指針的每一次遞減,它都會指向前一個元素的存儲單元。
指針在遞增和遞減時跳躍的位元組數取決于指針所指向變量資料類型長度,比如 int 就是 4 個位元組。
一、遞增一個指針
我們喜歡在程式中使用指針代替數組,因為變量指針可以遞增,而數組不能遞增,數組可以看成一個指針常量。下面的程式遞增變量指針,以便順序通路數組中的每一個元素:
執行個體
#include <stdio.h>
const int MAX = 3;
int main ()
{
int var[] = {10, 100, 200};
int i, *ptr;
/* 指針中的數組位址 */
ptr = var;
for ( i = 0; i < MAX; i++)
{
printf("存儲位址:var[%d] = %p\n", i, ptr );
printf("存儲值:var[%d] = %d\n", i, *ptr );
/* 指向下一個位置 */
ptr++;
}
return 0;
}
當上面的代碼被編譯和執行時,它會産生下列結果:
存儲位址:var[0] = e4a298cc
存儲值:var[0] = 10
存儲位址:var[1] = e4a298d0
存儲值:var[1] = 100
存儲位址:var[2] = e4a298d4
存儲值:var[2] = 200
二、遞減一個指針
同樣地,對指針進行遞減運算,即把值減去其資料類型的位元組數,如下所示:
執行個體
#include <stdio.h>
const int MAX = 3;
int main ()
{
int var[] = {10, 100, 200};
int i, *ptr;
/* 指針中最後一個元素的位址 */
ptr = &var[MAX-1];
for ( i = MAX; i > 0; i--)
{
printf("存儲位址:var[%d] = %p\n", i-1, ptr );
printf("存儲值:var[%d] = %d\n", i-1, *ptr );
/* 指向下一個位置 */
ptr--;
}
return 0;
}
當上面的代碼被編譯和執行時,它會産生下列結果:
存儲位址:var[2] = 518a0ae4
存儲值:var[2] = 200
存儲位址:var[1] = 518a0ae0
存儲值:var[1] = 100
存儲位址:var[0] = 518a0adc
存儲值:var[0] = 10
三、指針的比較
指針可以用關系運算符進行比較,如 ==、< 和 >。如果 p1 和 p2 指向兩個相關的變量,比如同一個數組中的不同元素,則可對 p1 和 p2 進行大小比較。
下面的程式修改了上面的執行個體,隻要變量指針所指向的位址小于或等于數組的最後一個元素的位址 &var[MAX - 1],則把變量指針進行遞增:
執行個體
#include <stdio.h>
const int MAX = 3;
int main ()
{
int var[] = {10, 100, 200};
int i, *ptr;
/* 指針中第一個元素的位址 */
ptr = var;
i = 0;
while ( ptr <= &var[MAX - 1] )
{
printf("存儲位址:var[%d] = %p\n", i, ptr );
printf("存儲值:var[%d] = %d\n", i, *ptr );
/* 指向上一個位置 */
ptr++;
i++;
}
return 0;
}
當上面的代碼被編譯和執行時,它會産生下列結果:
存儲位址:var[0] = 0x7ffeee2368cc
存儲值:var[0] = 10
存儲位址:var[1] = 0x7ffeee2368d0
存儲值:var[1] = 100
存儲位址:var[2] = 0x7ffeee2368d4
存儲值:var[2] = 200