組裝眶诈,當(dāng)數(shù)據(jù)元素類(lèi)型不一樣時(shí)故黑,程序員組裝新的數(shù)據(jù)類(lèi)型。拇泣。
關(guān)鍵字 struct Liujian // 定義一種新類(lèi)型
{
char name [20];
int age; //數(shù)據(jù)元素類(lèi)型
char addr[120];
double soore;
}铐料;
分配字節(jié)數(shù)20+4+120+8=152(首地址對(duì)齊,并且是最大偏移量的整數(shù)倍)
int main()
{
Liujian a1; //使用結(jié)構(gòu)體
Liujian a2{ “張三”钠惩,“18”柒凉,“南陽(yáng)”,“88”}篓跛;//初始化結(jié)構(gòu)體哦
a1=a2膝捞;
a1.name = “張三”; //buxing ,因?yàn)閿?shù)組沒(méi)分配空間
a1.age = 18 愧沟;可以
include《cstring》 需要頭文件
可以通過(guò)更好方法 strcpy(字符數(shù)組名蔬咬,字符串);
strlen(字符串或字符數(shù)組名)字符長(zhǎng)度
strcmp(str1沐寺,str2) 比較兩個(gè)字符串
strcat(字符數(shù)組名林艘,字符串) 將后面的字符串追加到數(shù)組名的字符串后頭
}
include <iostream>
//#include <algorithm>
using namespace std;
struct Student{
int age;
char name;
double score;
float hear;
short two;
//偏移量分析:1.首地址對(duì)其 2.總字符量占最大偏移量的整數(shù)倍 4+1+3+8+4+2+2 =24 (最后一個(gè)二是因?yàn)椋傋址坎皇?的整數(shù)倍混坞,自動(dòng)補(bǔ)全)
};
struct Student{
int age;
char name[20];
double score;
float hear;
short two;
//偏移量分析:1.首地址對(duì)其 2.總字符量占最大偏移量的整數(shù)倍 4+20+8+4+2+2 =40 (最后一個(gè)二是因?yàn)楹傋址坎皇?的整數(shù)倍,自動(dòng)補(bǔ)全,并且在char分配中是一個(gè)一個(gè)分配的究孕,不是一下分配20個(gè)字節(jié)給name)
};
main()
{
Student a1;
cout << sizeof(a1) <<endl;
return 0;
}
pragmapack(push) //保存對(duì)齊狀態(tài)
pragmapack(4)//設(shè)定為4字節(jié)對(duì)齊
struct test
{
char m1;
double m4;
int m3;
};
pragmapack(pop)//恢復(fù)對(duì)齊狀態(tài)
以上結(jié)構(gòu)的大小為16啥酱,下面分析其存儲(chǔ)情況,首先為m1分配空間厨诸,其偏移量為0镶殷,滿足我們自己設(shè)定的對(duì)齊方式(4字節(jié)對(duì)齊),m1占用1個(gè)字節(jié)微酬。接著開(kāi)始為m4分配空間绘趋,這時(shí)其偏移量為1,需要補(bǔ)足3個(gè)字節(jié)得封,這樣使偏移量滿足為n=4的倍數(shù)(因?yàn)閟izeof(double)大于n),m4占用8個(gè)字節(jié)埋心。接著為m3分配空間,這時(shí)其偏移量為12忙上,滿足為4的倍數(shù)拷呆,m3占用4個(gè)字節(jié)。這時(shí)已經(jīng)為所有成員變量分配了空間疫粥,共分配了16個(gè)字節(jié)茬斧,滿足為n的倍數(shù)。如果把上面的#pragmapack(4)改為#pragma pack(8)梗逮,那么我們可以得到結(jié)構(gòu)的大小為24项秉。