sizeof

来源:互联网 发布:android 移动网络 编辑:程序博客网 时间:2024/06/06 02:07
#include<iostream>
#include<stddef.h>
using namespace std;
//数组是“传址调用”的,调用者只需将实参的地址传递过去
/*void foo3(char a3[3])
{
cout<<"a3:"<<sizeof(a3)<<endl;

}
void foo4(char a4[])
{
cout<<"a4:"<<sizeof(a4)<<endl;
}*/


int main()
{
//1、基本数据类型  省略
//2、指针变量  所以在32位计算机中,一个指针变量的返回值必定是4
/*int m = 9;
int n[2][3] ; 
char* p1 = "abc";
int * p2 = &m;


void (*p4)();
cout<<"p1:"<<sizeof(p1)<<endl;
cout<<"p2:"<<sizeof(p2)<<endl;
cout<<"p4:"<<sizeof(p4)<<endl;
//3、数组
//求数组元素个数 sizeof(a1)/sizeof(char)
//sizeof(a2)/sizeof(int)
char* a1 = "abc";
char a2[3];
cout<<"a1:"<<sizeof(a1)<<endl;
cout<<"a2"<<sizeof(a2)<<endl;
char b[3] ;
foo3(b);
foo4(b);*/

//4、结构体  结构体的大小等于最后一个成员的偏移量加上其大小再加上末尾的填充字节数目
//#pragma pack( n ),n为字节对齐数,结构体成员的偏移量应该取二者的最小值,offsetof( item ) = min( n, sizeof( item ) )
//#pragma pack(pop) // 恢复先前的pack设置

//还有一点要注意,“空结构体”(不含数据成员)的大小不为0,而是1。

/*实际上,由于存储变量时地址对齐的要求,编译器在编译程序时会遵循两条原则:一、结构体变量中成员的偏移量必须是成员大小的整数倍(0被认为是任何数的整数倍) 二、结构体大小必须是所有成员大小的整数倍。*/

struct s1
{
 char c;
 int n;
 char c2;
 char c3;
  char c5;
 int n2;
 char c4;
 double m;
};
int pos = offsetof(s1,c5);
cout<<pos<<endl;
//5、联合体;联合体共享一段内存,所以整个联合体的sizeof也就是成员中最大的sizeof
union U
{
int i;
char c;
double d;
};
cout<<"U:"<<sizeof(U)<<endl;

return 0;

}
0 0
原创粉丝点击