สมมติว่าเรามีตัวแปรจำนวนเต็มหนึ่งตัวที่มีขนาด 4 ไบต์ ตัวแปรตัวชี้อีกตัวหนึ่งอยู่ที่นั่นซึ่งมีขนาด 8 ไบต์ แล้วผลลัพธ์ต่อไปนี้จะเป็นอย่างไร?
ตัวอย่าง
#include<iostream> using namespace std; main() { int a[4][5][6]; int x = 0; int* a1 = &x; int** a2 = &a1; int*** a3 = &a2; cout << sizeof(a) << " " << sizeof(a1) << " " << sizeof(a2) << " " << sizeof(a3) << endl; cout << (char*)(&a1 + 1) - (char*)&a1 << " "; cout << (char*)(&a2 + 1) - (char*)&a2 << " "; cout << (char*)(&a3 + 1) - (char*)&a3 << " "; cout << (char*)(&a + 1) - (char*)&a << endl; cout << (char*)(a1 + 1) - (char*)a1 << " "; cout << (char*)(a2 + 1) - (char*)a2 << " "; cout << (char*)(a3 + 1) - (char*)a3 << " "; cout << (char*)(a + 1) - (char*)a << endl; cout << (char*)(&a[0][0][0] + 1) - (char*)&a[0][0][0] << " "; cout << (char*)(&a[0][0] + 1) - (char*)&a[0][0] << " "; cout << (char*)(&a[0] + 1) - (char*)&a[0] << " "; cout << (char*)(&a + 1) - (char*)&a << endl; cout << (a[0][0][0] + 1) - a[0][0][0] << " "; cout << (char*)(a[0][0] + 1) - (char*)a[0][0] << " "; cout << (char*)(a[0] + 1) - (char*)a[0] << " "; cout << (char*)(a + 1) - (char*)a; }
เพื่อแก้ปัญหานี้ เราสามารถทำตามประเด็นสำคัญด้านล่าง −
-
ขนาดจำนวนเต็มคือ 4 ไบต์ (32 บิต) และขนาดตัวชี้คือ 8 ไบต์ ถ้าเราบวก 1 ด้วยพอยน์เตอร์ มันจะชี้ไปที่ประเภทถัดไปทันที
-
&a1 เป็นประเภท int**, &a2 เป็น int*** และ &a3 เป็นประเภท int**** ทั้งหมดนี้ชี้ไปที่ตัวชี้ ถ้าเราบวก 1 เรากำลังเพิ่ม 8 ไบต์
-
a[0][0][0] เป็นจำนวนเต็ม &a[0][0][0] เป็น int*, a[0][0] เป็น int*, &a[0][0] เป็นประเภท int (*)[6] และอื่นๆ ดังนั้น &a เป็นประเภท int(*)[4][5][6].
ผลลัพธ์
480 8 8 8 8 8 8 480 4 8 8 120 4 24 120 480 1 4 24 120