Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> การเขียนโปรแกรม C

ปริศนาตัวชี้ C/C++?


สมมติว่าเรามีตัวแปรจำนวนเต็มหนึ่งตัวที่มีขนาด 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