為什么?C ?中成員函數(shù)指針是?16?字節(jié)?
[導(dǎo)讀]關(guān)注、星標(biāo)公眾號,直達(dá)精彩內(nèi)容來源:明日科技當(dāng)我們討論指針時,通常假設(shè)它是一種可以用?void*?指針來表示的東西,在x86_64平臺下是8個字節(jié)大小。例如,下面是來自?維基百科中關(guān)于x86_64的文章?的摘錄:Pushesandpopsonthestackarealwaysin...
來源:明日科技
int main() {
std::cout <<
"sizeof(int*) == " << sizeof(int*) << "\n"
"sizeof(double*) == " << sizeof(double*) << "\n"
"sizeof(void(*)()) == " << sizeof(void(*)()) << std::endl;
} 編譯運行上面的程序,從結(jié)果中可以看出所有的指針的長度都是 8 個字節(jié):
x86_64
$ g -Wall ./example.cc
$ ./a.out
sizeof(int*) == 8
sizeof(double*) == 8
sizeof(void(*)()) == 8 然而在 C 中還有一種特例——成員函數(shù)的指針。很有意思吧,成員函數(shù)指針是其它任何指針長度的兩倍。這可以通過下面簡單的程序來驗證,輸出的結(jié)果是 “16”:
struct Foo {
void bar() const { }
};
int main() {
std::cout << sizeof(
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 平臺下都是由 64 位來表示,所以假設(shè)它是 8 個字節(jié)是正確的。通過簡單輸出不同類型指針的長度,這也不難驗證我們所說的。
int main() {
std::cout <<
"sizeof(int*) == " << sizeof(int*) << "\n"
"sizeof(double*) == " << sizeof(double*) << "\n"
"sizeof(void(*)()) == " << sizeof(void(*)()) << std::endl;
} 編譯運行上面的程序,從結(jié)果中可以看出所有的指針的長度都是 8 個字節(jié):
x86_64
$ g -Wall ./example.cc
$ ./a.out
sizeof(int*) == 8
sizeof(double*) == 8
sizeof(void(*)()) == 8 然而在 C 中還有一種特例——成員函數(shù)的指針。很有意思吧,成員函數(shù)指針是其它任何指針長度的兩倍。這可以通過下面簡單的程序來驗證,輸出的結(jié)果是 “16”:
struct Foo {
void bar() const { }
};
int main() {
std::cout << sizeof(





