C++ 指針的算術(shù)運(yùn)算
指針是一個(gè)用數(shù)值表示的地址。因此,您可以對(duì)指針執(zhí)行算術(shù)運(yùn)算??梢詫?duì)指針進(jìn)行四種算術(shù)運(yùn)算:++、--、+、-。
假設(shè) ptr 是一個(gè)指向地址 1000 的整型指針,是一個(gè) 32 位的整數(shù),讓我們對(duì)該指針執(zhí)行下列的算術(shù)運(yùn)算:
ptr++
在執(zhí)行完上述的運(yùn)算之后,ptr 將指向位置 1004,因?yàn)?ptr 每增加一次,它都將指向下一個(gè)整數(shù)位置,即當(dāng)前位置往后移 4 個(gè)字節(jié)。這個(gè)運(yùn)算會(huì)在不影響內(nèi)存位置中實(shí)際值的情況下,移動(dòng)指針到下一個(gè)內(nèi)存位置。如果 ptr 指向一個(gè)地址為 1000 的字符,上面的運(yùn)算會(huì)導(dǎo)致指針指向位置 1001,因?yàn)橄乱粋€(gè)字符位置是在 1001。
1. 遞增一個(gè)指針
我們喜歡在程序中使用指針代替數(shù)組,因?yàn)樽兞恐羔樋梢赃f增,而數(shù)組不能遞增,因?yàn)閿?shù)組是一個(gè)常量指針。下面的程序遞增變量指針,以便順序訪問數(shù)組中的每一個(gè)元素:
#include <iostream> using namespace std; const int MAX = 3; int main () { int var[MAX] = {10, 100, 200}; int *ptr; // 指針中的數(shù)組地址 ptr = var; for (int i = 0; i < MAX; i++) { cout << "Address of var[" << i << "] = "; cout << ptr << endl; cout << "Value of var[" << i << "] = "; cout << *ptr << endl; // 移動(dòng)到下一個(gè)位置 ptr++; } return 0; }
當(dāng)上面的代碼被編譯和執(zhí)行時(shí),它會(huì)產(chǎn)生下列結(jié)果:
Address of var[0] = 0xbfa088b0 Value of var[0] = 10 Address of var[1] = 0xbfa088b4 Value of var[1] = 100 Address of var[2] = 0xbfa088b8 Value of var[2] = 200
2. 遞減一個(gè)指針
同樣地,對(duì)指針進(jìn)行遞減運(yùn)算,即把值減去其數(shù)據(jù)類型的字節(jié)數(shù),如下所示:
#include <iostream> using namespace std; const int MAX = 3; int main () { int var[MAX] = {10, 100, 200}; int *ptr; // 指針中最后一個(gè)元素的地址 ptr = &var[MAX-1]; for (int i = MAX; i > 0; i--) { cout << "Address of var[" << i << "] = "; cout << ptr << endl; cout << "Value of var[" << i << "] = "; cout << *ptr << endl; // 移動(dòng)到下一個(gè)位置 ptr--; } return 0; }
當(dāng)上面的代碼被編譯和執(zhí)行時(shí),它會(huì)產(chǎn)生下列結(jié)果:
Address of var[3] = 0xbfdb70f8 Value of var[3] = 200 Address of var[2] = 0xbfdb70f4 Value of var[2] = 100 Address of var[1] = 0xbfdb70f0 Value of var[1] = 10
3. 指針的比較
指針可以用關(guān)系運(yùn)算符進(jìn)行比較,如 ==、< 和 >。如果 p1 和 p2 指向兩個(gè)相關(guān)的變量,比如同一個(gè)數(shù)組中的不同元素,則可對(duì) p1 和 p2 進(jìn)行大小比較。
下面的程序修改了上面的實(shí)例,只要變量指針?biāo)赶虻牡刂沸∮诨虻扔跀?shù)組的最后一個(gè)元素的地址 &var[MAX - 1],則把變量指針進(jìn)行遞增:
#include <iostream> using namespace std; const int MAX = 3; int main () { int var[MAX] = {10, 100, 200}; int *ptr; // 指針中第一個(gè)元素的地址 ptr = var; int i = 0; while ( ptr <= &var[MAX - 1] ) { cout << "Address of var[" << i << "] = "; cout << ptr << endl; cout << "Value of var[" << i << "] = "; cout << *ptr << endl; // 指向上一個(gè)位置 ptr++; i++; } return 0; }
當(dāng)上面的代碼被編譯和執(zhí)行時(shí),它會(huì)產(chǎn)生下列結(jié)果:
Address of var[0] = 0xbfce42d0 Value of var[0] = 10 Address of var[1] = 0xbfce42d4 Value of var[1] = 100 Address of var[2] = 0xbfce42d8 Value of var[2] = 200
- C++ 基本語法
- C++ 數(shù)組
- C++ 字符串
- C++ 重載運(yùn)算符和重載函數(shù)
- C++ 異常處理
- C++ 模板
- C++ vector 用法
- C++ 面試題
- C語言 變量
- C語言 運(yùn)算符
- C語言 預(yù)處理器
- C語言 標(biāo)準(zhǔn)庫 <assert.h>
- C語言 標(biāo)準(zhǔn)庫 <float.h>
- C# 循環(huán)語句
- C# 字符串 String
- C# 匿名方法
- C++ 傳遞數(shù)組給函數(shù)
- C語言 庫函數(shù) strftime()
- C# 參數(shù)數(shù)組
- C# 嵌套 switch 語句