來源:明日科技
當我們討論指針時,通常假設它是一種可以用void *指針來表示的東西,在 x86_64 平臺下是 8 個字節(jié)大小。例如,下面是來自 維基百科中關于 x86_64 的文章 的摘錄:
Pushes and pops on the stack are always in 8-byte strides, and pointers are 8 bytes wide.
從 CPU 的角度來看,指針無非就是內存的地址,所有的內存地址在 x86_64 平臺下都是由 64 位來表示,所以假設它是 8 個字節(jié)是正確的。通過簡單輸出不同類型指針的長度,這也不難驗證我們所說的。
#include
int main() {
std::
cout <<
"sizeof(int*) == " <<
sizeof(
int*) <<
"\n"
"sizeof(double*) == " <<
sizeof(
double*) <<
"\n"
"sizeof(void(*)()) == " <<
sizeof(
void(*)()) <<
std::
endl;
}
編譯運行上面的程序,從結果中可以看出所有的指針的長度都是 8 個字節(jié):
$ uname -i
x86_64
$ g -Wall ./example.cc
$ ./a.
out
sizeof(
int*) ==
8
sizeof(
double*) ==
8
sizeof(
void(*)()) ==
8 然而在 C 中還有一種特例——成員
函數(shù)的指針。很有意思吧,成員
函數(shù)指針是其它任何指針長度的兩倍。這可以通過下面簡單的程序來驗證,輸出的結果是 “16”:
#include
struct Foo {
void bar()
const { }
};
int main() {
std::
cout <<
sizeof(
本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。