一、定義/聲明方式
第一種:僅有結構體名,不定義/聲明變量
struct MyStruct{
int i;
char a[10];
double b;
};
第二種:有結構體名,並聲明變量名
struct MyStruct
{
int i;
char a[10];
double b;
}structName;
或
struct MyStruct
{
int i;
char a[10];
double b;
};
struct MyStruct structName;
//可同時定義,如struct MyStruct structName={7,“xxxxxxxxxx”,2.1};
//也可結構體之間直接賦值,如struct MyStruct structName = structName1;
//以上爲c風格,c++中struct MyStruct structName可省略struct ,也可不省。
第三種:無結構體名,直接聲明變量(對於該結構體,只需要聲明一個變量)
struct
{
int i;
char a[10];
double b;
}structName;
第四種:帶typedef
typedef struct MyStruct
{
int i;
char a[10];
double b;
}structName;
則structName=struct MyStruct,structName是結構體類型的別名,不是變量。
可以有structName aa=struct MyStruct aa;
也可以這樣:
typedef struct
{
int i;
char a[10];
double b;
}structName;
可以直接structName aa,效果跟上面一樣。
typedef主要是爲了省事,對於c語言定義結構體變量時總要帶上struct關鍵字,typedef之後就不用了,而c++本身就
不需要struct關鍵字,所以貌似也不需要typedef。
二、對齊方式
如:struct MyStruct
{
double dda1;
char dda;
int type;
};
int i = sizeof(MyStruct);
經vs2008測試i=16,“sizeof(MyStruct)=sizeof(double)+sizeof(char)+sizeof(int)=13”是不對的。這是VC對變量存儲的一個特殊處理,爲了提高CPU的存儲速度,VC對一些變量的起始地址做了“對齊”處理。在默認情況下,VC規定各成員變量存放的起始地址相對於結構的起始地址的偏移量必須爲該變量的類型所佔用的字節數的倍數。
對於上例,16=8+1+3+4,剛好爲結構的字節邊界數(即結構中佔用最大空間的類型所佔用的字節數sizeof(double)=8)的倍數,所以沒有空缺的字節需要填充。
所以整個結構的大小爲:sizeof(MyStruct)=8+1+3+4=16,其中有3個字節是VC自動填充的,沒有放任何有意義的東西。
又如:
structMyStruct
{
char dda;
double dda1;
int type;
};
sizeof(MyStruct)爲24=1+7+8+4+4;11個字節是vc自動填充的,最後加的4是爲了讓結構的字節邊界數爲結
構中佔用最大空間的類型所佔用的字節數的倍數。