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

更新於:2019-年 8 月 19 日

275 次瀏覽

職業生涯啟動指南

完成課程,獲得認證

開始
廣告
© . All rights reserved.