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