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