C 教程
C 指針是一個用數(shù)值表示的地址。因此,您可以對指針執(zhí)行算術(shù)運算??梢詫χ羔樳M行四種算術(shù)運算:++、--、+、-。
假設 ptr 是一個指向地址 1000 的整型指針,是一個 32 位的整數(shù),讓我們對該指針執(zhí)行下列的算術(shù)運算:
ptr++
在執(zhí)行完上述的運算之后,ptr 將指向位置 1004,因為 ptr 每增加一次,它都將指向下一個整數(shù)位置,即當前位置往后移 4 字節(jié)。這個運算會在不影響內(nèi)存位置中實際值的情況下,移動指針到下一個內(nèi)存位置。如果 ptr 指向一個地址為 1000 的字符,上面的運算會導致指針指向位置 1001,因為下一個字符位置是在 1001。
我們概括一下:
我們喜歡在程序中使用指針代替數(shù)組,因為變量指針可以遞增,而數(shù)組不能遞增,數(shù)組可以看成一個指針常量。下面的程序遞增變量指針,以便順序訪問數(shù)組中的每一個元素:
當上面的代碼被編譯和執(zhí)行時,它會產(chǎn)生下列結(jié)果:
存儲地址:var[0] = bf882b30 存儲值:var[0] = 10 存儲地址:of var[1] = bf882b34 存儲值: var[1] = 100 存儲地址:of var[2] = bf882b38 存儲值:var[2] = 200
同樣地,對指針進行遞減運算,即把值減去其數(shù)據(jù)類型的字節(jié)數(shù),如下所示:
當上面的代碼被編譯和執(zhí)行時,它會產(chǎn)生下列結(jié)果:
存儲地址:var[2] = 518a0ae4 存儲值:var[2] = 200 存儲地址:var[1] = 518a0ae0 存儲值:var[1] = 100 存儲地址:var[0] = 518a0adc 存儲值:var[0] = 10
指針可以用關(guān)系運算符進行比較,如 ==、< 和 >。如果 p1 和 p2 指向兩個相關(guān)的變量,比如同一個數(shù)組中的不同元素,則可對 p1 和 p2 進行大小比較。
下面的程序修改了上面的實例,只要變量指針所指向的地址小于或等于數(shù)組的最后一個元素的地址 &var[MAX - 1],則把變量指針進行遞增:
當上面的代碼被編譯和執(zhí)行時,它會產(chǎn)生下列結(jié)果:
Address of var[0] = bfdbcb20 Value of var[0] = 10 Address of var[1] = bfdbcb24 Value of var[1] = 100 Address of var[2] = bfdbcb28 Value of var[2] = 200其他擴展