為什么?C ?中成員函數(shù)指針是?16?字節(jié)?
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é)是正確的。通過簡(jiǎn)單輸出不同類型指針的長(zhǎng)度,這也不難驗(yàn)證我們所說的。
int main() {
std::cout <<
"sizeof(int*) == " << sizeof(int*) << "\n"
"sizeof(double*) == " << sizeof(double*) << "\n"
"sizeof(void(*)()) == " << sizeof(void(*)()) << std::endl;
} 編譯運(yùn)行上面的程序,從結(jié)果中可以看出所有的指針的長(zhǎng)度都是 8 個(gè)字節(jié):
x86_64
$ g -Wall ./example.cc
$ ./a.out
sizeof(int*) == 8
sizeof(double*) == 8
sizeof(void(*)()) == 8 然而在 C 中還有一種特例——成員函數(shù)的指針。很有意思吧,成員函數(shù)指針是其它任何指針長(zhǎng)度的兩倍。這可以通過下面簡(jiǎn)單的程序來驗(yàn)證,輸出的結(jié)果是 “16”:
struct Foo {
void bar() const { }
};
int main() {
std::cout << sizeof(