结构体联合体.ppt

上传人:wuy****n92 文档编号:91084925 上传时间:2023-05-21 格式:PPT 页数:40 大小:644.50KB
返回 下载 相关 举报
结构体联合体.ppt_第1页
第1页 / 共40页
结构体联合体.ppt_第2页
第2页 / 共40页
点击查看更多>>
资源描述

《结构体联合体.ppt》由会员分享,可在线阅读,更多相关《结构体联合体.ppt(40页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、第11章结构体与联合体 11.1结构体&结构体是一种构造数据类型&用途:把不同类型的数据组合成一个整体-自定义数据类型结构体类型定义struct结构体名类型标识符成员名;类型标识符成员名;.;成员类型可以是基本型或构造型struct是关键字,不能省略合法标识符可省:无名结构体例structstudentintnum;charname20;charsex;intage;floatscore;charaddr30;namenumsexagescoreaddr2字节2字节20字节1字节4字节30字节.结构体类型定义描述结构的组织形式,不分配内存结构体类型定义的作用域例structstudentint

2、num;charname20;charsex;intage;floatscore;charaddr30;structstudentstu1,stu2;11.2结构体变量的定义先定义结构体类型,再定义结构体变量v一般形式:struct结构体名类型标识符成员名;类型标识符成员名;.;struct结构体名变量名表列;例#defineSTUDENTstructstudentSTUDENTintnum;charname20;charsex;intage;floatscore;charaddr30;STUDENTstu1,stu2;定义结构体类型的同时定义结构体变量一般形式:struct结构体名类型标识符

3、成员名;类型标识符成员名;.变量名表列;例structstudentintnum;charname20;charsex;intage;floatscore;charaddr30;stu1,stu2;直接定义结构体变量一般形式:struct类型标识符成员名;类型标识符成员名;.变量名表列;例structintnum;charname20;charsex;intage;floatscore;charaddr30;stu1,stu2;用无名结构体直接定义变量只能一次说明v结构体类型与结构体变量概念不同l类型:不分配内存;变量:分配内存l类型:不能赋值、存取、运算;变量:可以v结构体可嵌套v结构体成员

4、名与程序中变量名可相同,不会混淆v结构体类型及变量的作用域与生存期例structdateintmonth;intday;intyear;structstudentintnum;charname20;structdatebirthday;stu;num namebirthdaymonth day year例structstudentintnum;charname20;structdateintmonth;intday;intyear;birthday;stu;num namebirthdaymonth day year 11.3结构体变量的引用引用规则v结构体变量不能整体引用,只能引用变量成员v

5、可以将一个结构体变量赋值给另一个结构体变量v结构体嵌套时逐级引用成员(分量)运算符优先级:1结合性:从左向右引用方式:结构体变量名.成员名例structstudentintnum;charname20;charsex;intage;floatscore;charaddr30;stu1,stu2;stu1.num=10;stu1.score=85.5;stu1.score+=stu2.score;stu1.age+;例structstudentintnum;charname20;charsex;intage;floatscore;charaddr30;stu1,stu2;printf(“%d,%

6、s,%c,%d,%f,%sn”,stu1);()stu1=101,“WanLin”,M,19,87.5,“DaLian”;()例structstudentintnum;charname20;charsex;intage;floatscore;charaddr30;stu1,stu2;stu2=stu1;()例structstudentintnum;charname20;structdateintmonth;intday;intyear;birthday;stu1,stu2;num namebirthdaymonth day yearstu1.birthday.month=12;例structs

7、tudentintnum;charname20;charsex;intage;floatscore;charaddr30;stu1,stu2;if(stu1=stu2).()11.4结构体变量的初始化形式一:struct结构体名类型标识符成员名;类型标识符成员名;.;struct结构体名结构体变量=初始数据;例structstudentintnum;charname20;charsex;intage;charaddr30;structstudentstu1=112,“WangLin”,M,19,“200BeijingRoad”;形式二:struct结构体名类型标识符成员名;类型标识符成员名;.

8、结构体变量=初始数据;例structstudentintnum;charname20;charsex;intage;charaddr30;stu1=112,“WangLin”,M,19,“200BeijingRoad”;形式三:struct类型标识符成员名;类型标识符成员名;.结构体变量=初始数据;例structintnum;charname20;charsex;intage;charaddr30;stu1=112,“WangLin”,M,19,“200BeijingRoad”;11.5结构体数组结构体数组的定义三种形式:形式一:structstudentintnum;charname20;c

9、harsex;intage;structstudentstu2;形式二:structstudentintnum;charname20;charsex;intage;stu2;形式三:structintnum;charname20;charsex;intage;stu2;numnamesexagenumnamesexagestu0stu125B结构体数组初始化例structintnum;charname20;charsex;intage;stu=,;顺序初始化:structstudentintnum;charname20;charsex;intage;structstudentstu=100,“

10、WangLin”,M,20,101,“LiGang”,M,19,110,“LiuYan”,F,19;例structstudentintnum;charname20;charsex;intage;stu=,;分行初始化:structstudentintnum;charname20;charsex;intage;structstudentstu=100,“WangLin”,M,20,101,“LiGang”,M,19,110,“LiuYan”,F,19;全部初始化时维数可省结构体数组引用引用方式:结构体数组名下标.成员名structstudentintnum;charname20;charsex;

11、intage;str3;stu1.age+;strcpy(stu0.name,”ZhaoDa”);例统计候选人选票structpersoncharname20;intcount;leader3=“Li”,0,“Zhang”,0,”Wang“,0;main()inti,j;charleader_name20;for(i=1;i=10;i+)scanf(%s,leader_name);for(j=0;j3;j+)if(strcmp(leader_name,leaderj.name)=0)leaderj.count+;for(i=0;i3;i+)printf(%5s:%dn,leaderi.name

12、,leaderi.count);name countLiZhangWang000structdatainta,b,c;main()voidfunc(structdata);structdataarg;arg.a=27;arg.b=3;arg.c=arg.a+arg.b;printf(arg.a=%darg.b=%darg.c=%dn,arg.a,arg.b,arg.c);printf(CallFunc().n);func(arg);printf(arg.a=%darg.b=%darg.c=%dn,arg.a,arg.b,arg.c);voidfunc(structdataparm)printf

13、(parm.a=%dparm.b=%dparm.c=%dn,parm.a,parm.b,parm.c);printf(Process.n);parm.a=18;parm.b=5;parm.c=parm.a*parm.b;printf(parm.a=%dparm.b=%dparm.c=%dn,parm.a,parm.b,parm.c);printf(Return.n);arga:27b:3c:30(main)(func)parma:27b:3c:30arga:27b:3c:30(main)(func)parma:18b:5c:90arga:27b:3c:30(main)arga:27b:3c:3

14、0(main)例用结构体变量作函数参数链表 C语言中,变量存储空间的分配分为静态分配和动态分配。静态存储分配:先在程序说明部分进行变量的说明,然后在程序编译时分配适当的存储单元。这些存储单元一经分配,在它的生存期内是固定不变的。动态存储分配:在程序执行期间,通过“申请”分配指定的存储空间来存储数据,当有闲置不用的存储空间时,又可以随时将其释放。ANSI C标准为动态分配系统定义了三个函数:malloc、calloc、free。用户可以通过调用C语言的标准库函数来实现动态存储分配,从而得到或释放指定数目的内存空间。这些函数在头文件alloc.h及stdlib.h中声明。2.链表存储结构是一种动态

15、数据结构特点:(1)它包含的数据对象的个数及其相互关系可以按需要改变.(2)存储空间是程序根据需要在程序运行过程中向系统申请获得.(3)不要求逻辑上相邻的元素在物理位置上也相邻.(4)没有顺序存储结构所具有的弱点.单向链表的逻辑状态Qian Sun Li Zhou Wu WangHead 7 13 1 43 2537以上链表结构中只有一个方向的指针,因此又称为单链表,简称为链表。一般地,用户可根据链表存放的信息如存放学生信息就称为学生链表,存放职工信息就称为职工链表。在单链表,通常称它的数据元素为结点,每个结点都是一个结构体,至少包括两个成员:存储数据元素信息的成员称为数据域;存储直接后继结点

16、存储位置的成员称为指针域.显然,链表结点的指针域存放的地址类型与它自身的类型是相同的。这就是C语言中较为特殊的递归结构体或自引用结构体,这种结构体是指向自身结构体的指针。每个链表都有一个“头指针”head,整个链表的访问必须从头指针开始进行,头指针指示链表中的第一个结点的存储位置,习惯上将“头指针”head指示的链表简称为链表head,下同。同时,由于最后一个数据元素没有直接后继结点,则链表中最后一个结点的指针为“空”(NULL,即空地址)。表10-1 链表的存储地址与指针域的关系存储地址数据域 指针域head 71 Li 437 Qian 1313 Sun 125 Wu 3737 Wang

17、NULL43 Zhou 25 数据元素之间的逻辑关系是由结点中的指针指示的,逻辑上相邻的两个数据元素其存储的物理位置不要求紧邻,即链表中的数据元素在内存中不是顺序存放的,要访问其数据元素不能像数组一样按下标去查找。要找一个元素,必须先找到上一个元素,根据上一个元素的指针域才能找到下一个元素。因此,链表的数据元素访问必须从头指针开始,逐个访问链表的每个结点,直到元素的指针域为空为止。要使用链表,首先应定义结点的类型,再定义相应的结构体变量。例如,前面链表中结点的结构类型可以定义为:struct student char name10;struct student*next;其中,next为指针变

18、量,其类型为结构体类型student,它可存储一个student结构体类型变量的地址,即实现链表中指向下一个结点的指针域。这是一个递归定义,它在结构体student的定义未完成时又引用它定义其它的变量(指针变量)。引入链表后,用户就可以根据需要在程序的运行过程中动态分配存储空间。动态存储分配需要利用以下C语言库函数。(1)函数malloc 函数功能:函数原型:void*malloc(unsigned int size);在内存的动态存储区中分配一个长度为size的连续存储空间。其中,形参size为无符号整数,是函数malloc要求分配存储空间的字节个数。函数返回值为一个指针,它指向所分配存储空

19、间的起始地址。若函数返回值为0,则表示未能成功申请到内存空间。函数类型为void,表示返回的指针不指向任何具体的类型.int*p;long*lp;p=(int*)malloc(8);lp=(long*)malloc(12);head=(struct student*)malloc(sizeof(struct student);例如:malloc(8);通过函数malloc向系统申请8个字节的内存空间,其起始地址通过函数值返回。若要求用一个指针变量(具有某种类型)指向这个起始地址,则需要显式进行类型转换。例如:(2)函数calloc 函数原型:void calloc(unsigned int n

20、,unsigned int size);函数功能:在内存的动态存储区域中分配n个长度为size的连续存储空间。函数的返回值为分配域的起始地址;如果分配不成功,则返回值为0。例如:int*p;p=(int*)calloc(3,8);分配3个8字节的的连续存储空间,并将其起始地址赋给整型指针p。(3)函数free函数原型:void free(void*ptr);函数功能:释放由指针变量ptr为所指示的内存区域。其中,ptr一个指针变量,指向最近一次调用函数malloc或calloc时所分配的连续存储空间的首地址。通过函数free将已分配的内存区域交还系统,使系统可以重新对其进行分配。例如:long

21、*p;p=(long*)malloc(8);.free(p);例:动态分配一块区域,输入一个学生数据#include“string.h”#include“stdlib.h”main()structstuintnum;charname20;floatscore;*ps;ps=(structstu*)malloc(sizeof(structstu);ps num=102;strcpy(ps name,”zhangping”);ps score=62.5;printf(“Number=%dnName=%snScore=%.2fn”,ps num,ps name,ps score);free(ps);

22、Number=102Name=zhangpingScore=62.50例:写一函数,建立学生成绩单链表。从键盘输入每个学生的学号,姓名和成绩。当输入的学号为负数时,输入结束并返回链表的头指针。head=NULLlast=NULL输入第一个学生的信息while(num0)开辟新空间,并使p指向它将读入的数据赋给新结点pnext=NULLhead=NULLYNhead=plast next=plast=p输入下一个学生的信息返回链表头指针Structstu*creat()structstu*head;Structstu*last,*p;Intnum;Charname20;Floatscore;He

23、ad=last=NULL;Printf(“pleaseinputnumnamescore:n”);Scanf(“%d%s%f”,&num,name,&score);While(num0)p=(structstu*)malloc(sizeof(structstu);pnum=num;strcpy(p name,name);pscore=score;pnext=NULL;if(head=NULL)head=p;elselast next=p;last=p;scanf(“%d%s%f”,&num,name.&score);Return(head);Struct stuInt num;Char nam

24、e20;Float score;Struct stu*next;headlast phead 1wang85.0NULLlasthead 1wang85.0last 2 liu63.5NULL p 11.8联合体用途:使几个不同类型的变量共占一段内存(相互覆盖)联合体类型定义定义形式:union 联合体名 类型标识符 成员名;类型标识符 成员名;.;例uniondatainti;charch;floatf;类型定义不分配内存2000200120022003chif形式一:uniondatainti;charch;floatf;a,b;形式二:uniondatainti;charch;float

25、f;uniondataa,b,c,*p,d3;形式三:unioninti;charch;floatf;a,b,c;联合体变量的定义fchifchia b联合体变量定义分配内存,长度=最长成员所占字节数联合体变量任何时刻只有一个成员存在联合体变量引用v引用方式:例a.i=1;a.ch=a;a.f=1.5;printf(“%d”,a.i);(编译通过,运行结果不对)v引用规则l不能引用联合体变量,只能引用其成员联合体指针名-成员名 联合体变量名.成员名(*联合体指针名).成员名uniondatainti;charch;floatf;uniondataa,b,c,*p,d3;a.ia.cha.fp-

26、ip-chp-f(*p).i(*p).ch(*p).fd0.id0.chd0.fl联合体变量中起作用的成员是最后一次存放的成员例unioninti;charch;floatf;a;a=1;()l不能在定义联合体变量时初始化例unioninti;charch;floatf;a=1,a,1.5;()l可以用一个联合体变量为另一个变量赋值例floatx;unioninti;charch;floatf;a,b;a.i=1;a.ch=a;a.f=1.5;b=a;()x=a.f;()例将一个整数按字节输出0110000101000001低字节 高字节0100000101100001ch0ch1运行结果:i

27、=60501ch0=101,ch1=141ch0=A,ch1=amain()unionint_charinti;charch2;x;x.i=24897;printf(i=%on,x.i);printf(ch0=%o,ch1=%onch0=%c,ch1=%cn,x.ch0,x.ch1,x.ch0,x.ch1);枚举类型 所谓枚举,是将具有相同属性的一类数据值一一列举。一.枚举类型的定义1.enum 枚举类型名 标识符1,标识符2,标识符n;enum是枚举类型定义的关键字枚举类型名是用户命名的标识符,它与enum构成枚举类型的标识符花括号中“标识符1,标识符2,标识符n”是所定义枚举类型的全部取值

28、,通常称这些标识符为“枚举元素“或“枚举常量”。这些标识符是用户定义的标识符,一般是所代表事物的名称,但这些标识符并不自动地代表事物本身。例如 enum colorred,blue,green,black;用户可根据需要在定义时直接指定某一枚举元素的编号,从而改变量系统默认的编号。例如:enum week sun=7,mon,tue=2,wed,thu,fri,sat;则sun的序号为7,mon的序号为8,tue的序号为2,wed的序号为3,thu的序号为4,fri的序号为5,sat的序号为6。2.枚举类型是有序类型 一般地,枚举类型中各枚举元素按定义时的先后次序分别编号为0、1、2、.、n-

29、1。例如:redblue 值为真,各枚举元素可根据其序号进行大小比较和相应的运算green-red 值为2二.枚举类型的应用 1枚举类型变量的定义enum male,femalesex1,sex2;先定义枚举类型,再定义枚举类型变量enum weeksun,mon,tue,wed,thu,fri,sat;enum week weekday,workday;定义枚举类型的同时定义枚举变量enum color red,blue,green,blacka,b,c;直接定义枚举变量 例:编写程序,输入今天是星期几,计算并输出明天是星期几Enumweeksun,mon,tur,wed,thu,fri,s

30、atEnumweektomorrow(day)Enumday;intn;n=(int)day+1)%7;Return(enumweek)n);Main()enumweekday1,day2;Char*name=“sum”,”mon”,”tur”,”wed”,”fri”,”sat”;Intn;Printf(“n请输入06内的整数:”);Scanf(”%d”,&n);Day1=(enumweek)n;Day2=tomorrow(day1);Printf(“明天是:s”,name(int)day2);请输入06内的整数:3明天是:thu自定义类型(用typedef定义类型)功能:用自定义名字为已有数

31、据类型命名类型定义简单形式:typedeftypename;例typedefintINTEGER;类型定义语句关键字已有数据类型名用户定义的类型名例typedeffloatREAL;类型定义后,与已有类型一样使用例INTEGERa,b,c;REALf1,f2;inta,b,c;floatf1,f2;说明:1.typedef 没有创造新数据类型2.typedef 是定义类型,不能定义变量3.typedef 与 define 不同 define typedef预编译时处理 编译时处理简单字符置换 为已有类型命名 typedef定义类型步骤按定义变量方法先写出定义体如inti;将变量名换成新类型名如intINTEGER;最前面加typedef如typedefintINTEGER;用新类型名定义变量如INTEGERi,j;例定义结构体类型structdateintmonth;intday;intyear;d;例定义结构体类型structdateintmonth;intday;intyear;DATE;例定义结构体类型typedefstructdateintmonth;intday;intyear;DATE;例定义结构体类型DATEbirthday,*p;structdateintmonth;intday;intyear;birthday,*p;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 大学资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁