C语言进阶-第五讲数据结构与链表

C语言进阶-第五讲数据结构与链表

ID:36775557

大小:229.68 KB

页数:12页

时间:2019-05-15

C语言进阶-第五讲数据结构与链表_第1页
C语言进阶-第五讲数据结构与链表_第2页
C语言进阶-第五讲数据结构与链表_第3页
C语言进阶-第五讲数据结构与链表_第4页
C语言进阶-第五讲数据结构与链表_第5页
资源描述:

《C语言进阶-第五讲数据结构与链表》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、第五讲数据结构与链表凌明trio@seu.edu.cn东南大学国家专用集成电路系统工程技术研究中心www.cnasic.com目录结构,联合,枚举用结构构成链表单向链表双向链表循环双向链表窗口系统的数据结构与代码分析窗口系统的代码调试www.cnasic.com11结构体结构是由若干(可不同类型的)数据项组合而成的复合数据对象,这些数据项称为结构的成分或成员。(1)字段C语言的结构还提供了一种定义字段的机制,使人在需要时能把几个结构成员压缩到一个基本数据类型成员里存放,这可以看作是一种数据压缩表示方式。例16:st

2、ructpack{unsigneda:2;unsignedb:8;unsignedc:6;}pk1,pk2;结构变量pk1或者pk2的三个成员将总共占用16位存储,其中a占用2位,b占用8位,c占用6位。www.cnasic.com(2)结构体内部的成员的对齐在计算结构体长度(尤其是用sizeof)时,需要注意!根据不同的编译器和处理器,结构体内部的成员有不同的对齐方式,这会引起结构体长度的不确定性。例17:#includestructa{chara1;chara2;chara3;}A;struc

3、tb{shorta2;chara1;}B;voidmain(void){printf(“%d,%d,%d,%d”,sizeof(char),sizeof(short),sizeof(A),sizeof(B));}在TurboC2.0中结果都是1,2,3,3在VC6.0中是1,2,3,4www.cnasic.com2字节对齐的细节和编译器实现相关,但一般而言,满足三个准则:1)结构体变量的首地址能够被其最宽基本类型成员的大小所整除;2)结构体每个成员相对于结构首地址的偏移量(offset)都是成员大小的整数倍,如有需

4、要编译器会在成员之间加上填充字节(internaladding);3)结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要编译器会在最末一个成员之后加上填充字节(trailingpadding)。对于上面的准则,有几点需要说明:1)结构体某个成员相对于结构体首地址的偏移量可以通过宏offsetof()来获得,这个宏也在stddef.h中定义,如下:#defineoffsetof(s,m)(size_t)&(((s*)0)->m)2)基本类型是指前面提到的像char、short、int、float、doubl

5、e这样的内置数据类型,这里所说的“数据宽度”就是指其sizeof的大小。由于结构体的成员可以是复合类型,比如另外一个结构体,所以在寻找最宽基本类型成员时,应当包括复合类型成员的子成员,而不是把复合成员看成是一个整体。但在确定复合类型成员的偏移位置时则是将复合类型作为整体看待。www.cnasic.com2联合体在一个结构(变量)里,结构的各成员顺序排列存储,每个成员都有自己独立的存储位置。联合变量的所有成员共享从同一片存储区。因此一个联合变量在每个时刻里只能保存它的某一个成员的值。(1)联合变量的初始化联合变量也在

6、可以定义时直接进行初始化,但这个初始化只能对第一个成员做。例如下面的描述定义了一个联合变量,并进行了初始化:例18:uniondata{charn;floatf;};uniondatau1={3};//只有u1.n被初始化www.cnasic.com33枚举枚举是一种用于定义一组命名常量的机制,以这种方式定义的常量一般称为枚举常量。一个枚举说明不但引进了一组常量名,同时也为每个常量确定了一个整数值。缺省情况下其第一个常量自动给值0,随后的常量值顺序递增。(1)给枚举常量指定特定值与给变量指定初始值的形式类似。如果给

7、某个枚举量指定了值,跟随其后的没有指定值的枚举常量也将跟着顺序递增取值,直到下一个有指定值的常量为止。例如写出下面枚举说明:enumcolor{RED=1,GREEN,BLUE,WHITE=11,GREY,BLACK=15};这时,RED、GREEN,、BLUE的值将分别是1、2、3,WHITE、GREY的值将分别是11、12,而BLACK的值是15。www.cnasic.com(2)用枚举常量作为数组长度例19:typedefenum{WHITE,RED,BLUE,YELLOW,BLACK,COLOR_NUM}C

8、OLOR;……floatBallSize[COLOR_NUM];上例中当颜色数量发生变化时,只需在枚举类型定义中加入或删去颜色。无需修改COLOR_NUM的定义。与大量使用#define相比既简洁又可靠。如:typedefenum{WHITE,RED,BLUE,COLOR_NUM}COLOR;www.cnasic.com44sizeof的定义和使用sizeo

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。