sizeof()运算符返回一条表达式或者一个类型的名字所占用的字节数。sizeof运算符满足右结合律,其所得到的值是一个size_t类型的常量表达式。运算符的运算对象有两种形式:
sizeof(type)
sizeof expr
在第二种格式中,sizeof返回的是表达式结果类型的大小。与众不同的是,sizeof并不实际计算其运算对象的值:
#include<iostream>
using namespace std;
class Sales_data
{
public:
Sales_data();
~Sales_data();
int f;
private:
};
Sales_data::Sales_data()
{
}
Sales_data::~Sales_data()
{
}
int main()
{
Sales_data data, * p;
sizeof(Sales_data);//1
sizeof data;//2
sizeof p;//3
sizeof *p;//4
sizeof data.f;//5
sizeof Sales_data::f;//6
return 0;
}
- 存储的是Sales_data类型的对象所占的空间大小。
- data的类型大小,即sizeof(Sales_data)。
- 指针所占的空间的大小。即存储指针所需要的空间大小,一般是8.
- p所指类型的大小,即sizeof(Sales_data)。
- Sales_data的f成员对应类型的大小。
- 另一种获取f大小的方式。但这是C++11后出现的。
这些例子中最有趣的是:sizeof *p;。首先,因为sizeof的右结合性并且它的优先级和*相同,所以表达式按照从右向左的方式去组合。也就是说,它等价于sizeof (*p).其次,sizeof不会具体的去求运算对象的值,所以即使p是一个无效(即未初始化)的指针,也不会有什么影响。在sizeof的运算对象中解引用一个无效指针仍然是一个安全的行为,因为指针并没有被使用。
总结一下:
sizeof运算符的结果部分的依赖于其作用的类型:
- 对char或者类型为char的表达式执行sizeof运算,结果为1.
- 对引用类型执行sizeof运算得到被引用对象所占的空间的大小。
- 对指针执行sizeof运算得到指针本身所占的空间的大小。一般为8.
- 对解引用指针执行sizeof运算得到指针指向的对象所占空间的大小,指针不需要有效。
- 对数组执行sizeof运算得到整个数组所占的空间的大小,等价于对数组中所有的元素各自执行一次sizeof运算并将所得到的数据求和。注意sizeof并不会把数组转换成指针来处理。
- 对string对象或者vector对象执行sizeof运算只返回该类型固定部分的大小,不会计算对象中的元素占用了多少空间。
由于使用sizeo运算可以得到整个数组的大小,所以可以使用数组的大小除以单个元素的大小得到数组中元素的个数。
sizeof(ia)/sizeof(*ia)
最后大家理解一下下面的代码,进行好好的总结:
#include<iostream>
using namespace std;
int main()
{
int x[10], * p = x;
cout << sizeof(x) / sizeof(*x) << endl;
cout << sizeof(p) / sizeof(*p) << endl;
return 0;
}