欢迎来到天天文库
浏览记录
ID:17435959
大小:23.00 KB
页数:3页
时间:2018-08-31
《有关sizeof运算符的笔试题目》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、有关sizeof运算符的笔试题目#includeusingnamespacestd;intmain(){ char*p; char*q[20]; char*m[20][20]; int(*n)[10]; structMyStruct { chardda; doubledda1; inttype; }; structMyStructk; cout
2、<3、ndl; return0;}答案如下:4 指针所占字节为480 数组长度*指针所占字节=20*4=801600 同上4 指针所占字节为416 结构类型,与最大长度对齐原则 8+81 字符大小为18 双精度字节阿大小为84 整形为416 结构类型,与最大长度对齐原则 8+8楼主是正确的!32位机器默认是4字节对齐,所以只有double才会按4字节对齐。对于 structMyStruct { chardd4、a; doubledda1; inttype; };dda是char,所以占1字节;对double,是8字节,此时会按4字节对齐,在dda后填充3个字节,就是1+3+8;而对于int,按其自身4字节对齐,就是1+3+8+4=16。内存对齐节约内存 许多实际的计算机系统对基本类型数据在内存中存放的位置有限制,它们会要求这些数据的首地址的值是某个数k(通常它为4或8)的倍数,这就是所谓的内存对齐,而这个k则被称为该数据类型的对齐模数(alignmentmod5、ulus)。当一种类型S的对齐模数与另一种类型T的对齐模数的比值是大于1的整数,我们就称类型S的对齐要求比T强(严格),而称T比S弱(宽松)。这种强制的要求一来简化了处理器与内存之间传输系统的设计,二来可以提升读取数据的速度。比如这么一种处理器,它每次读写内存的时候都从某个8倍数的地址开始,一次读出或写入8个字节的数据,假如软件能保证double类型的数据都从8倍数地址开始,那么读或写一个double类型数据就只需要一次内存操作。否则,我们就可能需要两次内存操作才能完成这个动作,因为数据或许恰好横跨在两个6、符合对齐要求的8字节内存块上三个原则:1)结构体变量的首地址能够被其最宽基本类型成员的大小所整除;2)结构体每个成员相对于结构体首地址的偏移量(offset)都是成员大小的整数倍,如有需要编译器会在成员之间加上填充字节(internaladding);3)结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要编译器会在最末一个成员之后加上填充字节(trailingpadding)另外还可以用#prgampack(n)来指定偏移量的大小,n为字节对齐数,其取值为1、2、4、8、16,默认是8,如果这个7、值比结构体成员的sizeof值小,那么该成员的偏移量应该以此值为准,即是说,结构体成员的偏移量应该取二者的最小值。比如:对32位机器,指针大小为4structP1{inta;charb;intc;chard;}; //16 structP2{inta;charb;charc;intd;}; //12structP3{shorta[3];charb[3];}; //10structP4{shorta[3];char*b[3];}; //20structP5{structP2*a;c8、harb;structP1c[2]; };//40 而:structP6{inta;intb;charc;chard;}; //12structP7{inta;charb;charc;intd;}; //12structP8{shorta[3];charb[3];}; //10structP9{char*b[3];shorta[3]; }; //20structP10{structP2*a;str
3、ndl; return0;}答案如下:4 指针所占字节为480 数组长度*指针所占字节=20*4=801600 同上4 指针所占字节为416 结构类型,与最大长度对齐原则 8+81 字符大小为18 双精度字节阿大小为84 整形为416 结构类型,与最大长度对齐原则 8+8楼主是正确的!32位机器默认是4字节对齐,所以只有double才会按4字节对齐。对于 structMyStruct { chardd
4、a; doubledda1; inttype; };dda是char,所以占1字节;对double,是8字节,此时会按4字节对齐,在dda后填充3个字节,就是1+3+8;而对于int,按其自身4字节对齐,就是1+3+8+4=16。内存对齐节约内存 许多实际的计算机系统对基本类型数据在内存中存放的位置有限制,它们会要求这些数据的首地址的值是某个数k(通常它为4或8)的倍数,这就是所谓的内存对齐,而这个k则被称为该数据类型的对齐模数(alignmentmod
5、ulus)。当一种类型S的对齐模数与另一种类型T的对齐模数的比值是大于1的整数,我们就称类型S的对齐要求比T强(严格),而称T比S弱(宽松)。这种强制的要求一来简化了处理器与内存之间传输系统的设计,二来可以提升读取数据的速度。比如这么一种处理器,它每次读写内存的时候都从某个8倍数的地址开始,一次读出或写入8个字节的数据,假如软件能保证double类型的数据都从8倍数地址开始,那么读或写一个double类型数据就只需要一次内存操作。否则,我们就可能需要两次内存操作才能完成这个动作,因为数据或许恰好横跨在两个
6、符合对齐要求的8字节内存块上三个原则:1)结构体变量的首地址能够被其最宽基本类型成员的大小所整除;2)结构体每个成员相对于结构体首地址的偏移量(offset)都是成员大小的整数倍,如有需要编译器会在成员之间加上填充字节(internaladding);3)结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要编译器会在最末一个成员之后加上填充字节(trailingpadding)另外还可以用#prgampack(n)来指定偏移量的大小,n为字节对齐数,其取值为1、2、4、8、16,默认是8,如果这个
7、值比结构体成员的sizeof值小,那么该成员的偏移量应该以此值为准,即是说,结构体成员的偏移量应该取二者的最小值。比如:对32位机器,指针大小为4structP1{inta;charb;intc;chard;}; //16 structP2{inta;charb;charc;intd;}; //12structP3{shorta[3];charb[3];}; //10structP4{shorta[3];char*b[3];}; //20structP5{structP2*a;c
8、harb;structP1c[2]; };//40 而:structP6{inta;intb;charc;chard;}; //12structP7{inta;charb;charc;intd;}; //12structP8{shorta[3];charb[3];}; //10structP9{char*b[3];shorta[3]; }; //20structP10{structP2*a;str
此文档下载收益归作者所有