Chinaunix首页 | 论坛 | 博客
  • 博客访问: 783563
  • 博文数量: 231
  • 博客积分: 3217
  • 博客等级: 中校
  • 技术积分: 2053
  • 用 户 组: 普通用户
  • 注册时间: 2011-07-04 12:01
文章分类

全部博文(231)

文章存档

2015年(1)

2013年(10)

2012年(92)

2011年(128)

分类: LINUX

2012-08-27 13:19:46


点击(此处)折叠或打开

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<string>
  4. #include<cstdlib>
  5. using namespace std;
  6. struct{
  7. short a1;
  8. short a2;
  9. short a3;
  10. }A;
  11. struct{
  12. long a1;
  13. short a2;
  14. }B;

  15. int main()
  16. {
  17. char *s1="0123456789";
  18. char s2[]="0123456789";
  19. char s3[100]="0123456789";
  20. int s4[100];
  21. char q1[]="abc";
  22. char q2[]="a\n";
  23. char *q3="a\n";
  24. char *str1=(char *)malloc(100);

  25. cout<<sizeof(s1)<<" ";
  26. cout<<sizeof(s2)<<" ";
  27. cout<<sizeof(s3)<<" ";
  28. cout<<sizeof(q1)<<" ";
  29. cout<<sizeof(q2)<<" ";
  30. cout<<sizeof(q3)<<" ";
  31. cout<<sizeof(A)<<" ";
  32. cout<<sizeof(B)<<" ";
  33. cout<<sizeof(str1)<<" ";
  34. //cout<<sizeof(str2)<<" ";
  35.     cout<<sizeof(*str1)<<" ";
  36.     
  37.     return 0;
  38. }}

  39. 输出结果:4 11 100 4 3 4 6 8 4 1
A和B是两个结构体,在默认情况下方便对解雇内元素的访问和刮泥,当结构体内的元素的长度都小于处理器的位数的时候,变以结构体内最长的数据元素为堆积单元。
结构体A有三个short类型变量,各自以2字节对齐,结构体对齐按默认8字节对齐,则a1/a2/a3都取2字节对齐sizeof(A)为6,也是2的整数倍。B中a1为4字节对齐,a2为2字节对齐,结构体默认对齐参数为8,a1取4字节对齐,a2取2字节对齐,结构体大小为6字节,6不足4的整数倍不空字节增到8时符合条件sizeof(B)为8字节。
s1是一个字符指针,指针的大小是一个定值就是4字节。str1相似。
q2里面有一个'\n'算作一个位。
*str1大小为1字节。
 
 
指针和引用的差异:
非空区别:在任何情况下都不能使用指向空值的引用。一个引用必须总是指向某些对象。因此如果你使用一个变量并让它指向一个对象,但是该变量在某些时候也可能不指向任何对象。
合法性区别:在使用引用之前不需要测试它的合法性。相反,指针则应该总是被测试防止为空。
可修改区别:指针可以被重新赋值以指向另一个不同的对象,但是引用则总是指向初始化时被指定的对象,以后不能改变,但指定的对象其内容可以改变。
应用区别:考虑到存在不指向任何对象的可能,能够设置指针为空,二是需要能够在不同的时刻指向不同的对象,如果总是指向一个对象并且一旦指向一个对象后就不会改变指向那么应该使用引用。
阅读(1025) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~