#include <iostream>
using namespace std;
int main()
{
cout << "sizeof(bool) = " << sizeof(bool) << endl;
cout << "sizeof(char) = " << sizeof(char) << endl;
cout << "sizeof(int) = " << sizeof(int) << endl;
cout << "sizeof(float) = " << sizeof(float) << endl;
cout << "sizeof(double) = " << sizeof(double) << endl;
cout << "sizeof(long double) = " << sizeof(long double) << endl;
enum e{a, b=3};
cout << "sizeof(enum) = " << sizeof(e) << endl;
cout << "sizeof(int *) = " << sizeof(int *) << endl;
cout << "sizeof(char *) = " << sizeof(char *) << endl;
return 0;
}
运行结果:
sizeof(bool) = 1
sizeof(char) = 1
sizeof(int) = 4
sizeof(float) = 4
sizeof(double) = 8
sizeof(long double) = 16
sizeof(enum) = 4
sizeof(int *) = 8
sizeof(char *) = 8主要是在ubuntu64位下面sizeof(int *) 和 sizeof(char *)是8字节,也就是地址是64位。
解释是:在32位编译器上sizeof(指针)是4字节。在64位编译器上sizeof(指针)是8字节。32位地址最大寻址为4G=2^32,64位最大寻址为128T=2^64。

本文详细解释了C++中sizeof运算符的功能及其在不同编译器环境下(32位与64位)的行为差异,包括基本类型、指针类型以及枚举类型的大小。通过具体示例,揭示了在64位编译器上sizeof(int*)和sizeof(char*)为8字节的原因,即地址为64位寻址的特点。
1174

被折叠的 条评论
为什么被折叠?



