一、sizeof运算符满足右结合律,运算符的对象有两种形式:
sizeof(type)
sizeof expr
第二种形式中,sizeof返回的表达式结果类型的大小。
二、在sizeof的运算对象中解引用一个无效指针仍然是一种安全行为,因为指针实际上并没有真正被使用。sizeof不需要真的解引用指针也能知道它所指对象的类型。
三、习题:
(1)编写一段程序,输出每一种内置类型所占空间的大小。
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main()
{
cout << sizeof(float) << endl;//其他的类型的验证只需要更换sizeof()括号内的内容即可
}
(2)推断下面代码的输出结果并说明理由。实际运行这段程序,结果跟你想像的一样吗?如果不一样?为什么?
int x[10]; int *p = x;
cout<<sizeof(x)/sizeof(*x)<<endl;
cout<<sizeof(p)/sizeof(*p)<<endl;
解析:这里主要考察sizeof函数的使用辨析,在对数组使用时,返回的是数组的大小;在对指针使用是,返回的是指针本身的大小,32位机器的话就是1;所以输出结果为10 ; 1
四、根据4.12节中表(第147页),在下述表达式的适当位置加上括号,使得加上括号之后表达式的含义与原来的含义相同。
(a)sizeof x+y
(b) sizeof p->men[i]
(c)sizeof a<b
(d)sizeof f ()
解析:主要就是使用运算符优先级的知识点
(a) (sizeof x) +y
(b) sizeof(p->mem[i])
(c) (sizeof a) < b
(d) 无需改变。