当前位置:主页   - 电脑 - 程序设计 - C/C++
C语言学习笔记整理
来源:网络   作者:   更新时间:2012-03-07
收藏此页】    【字号    】    【打印】    【关闭

  一.sizeof()

  1.sizeof的使用:sizeof操作符以字节形式给出了其操作数的存储大小.

  sizeof操作符不能用于函数类型,不完全类型或位字段。不完全类型指具有未知存储大小的数据类型,如未知存储大小的数组类型、未知内容的结构或联合类型、void类型等。

  2.sizeof的结果:sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。该类型保证能容纳实现所建立的最大对象的字节大小。

  int、unsigned int 、short int、unsigned short 、long int 、unsigned long 、float、double、long double类型的sizeof 在ANSI C中没有具体规定,大小依赖于实现,一般可能分别为2、2、2、2、4、4、4、8、10。

  当操作数是指针时,sizeof依赖于编译器。near类指针字节数为2,far、huge类指针字节数为4。一般Unix的指针字节数为4。

  当操作数具有数组类型时,其结果是数组的总字节数,联合类型操作数的sizeof是其最大字节成员的字节数。

  结构类型操作数的sizeof是这种类型对象的总字节数,包括任何垫补在内.

  如果操作数是函数中的数组形参或函数类型的形参,sizeof给出其指针的大小。

  struct MyStruct

  {

  char dda;//偏移量为0,满足对齐方式,dda占用1个字节;

  double dda1;//下一个可用的地址的偏移量为1,不是sizeof(double)=8

  //的倍数,需要补足7个字节才能使偏移量变为8(满足对齐

  //方式),因此VC自动填充7个字节,dda1存放在偏移量为8

  //的地址上,它占用8个字节。

  int type;//下一个可用的地址的偏移量为16,是sizeof(int)=4的倍

  //数,满足int的对齐方式,所以不需要VC自动填充,type存

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明