美文网首页C语言
第十一章-结构体与共用体(知识点)

第十一章-结构体与共用体(知识点)

作者: 逆流而上jiao | 来源:发表于2020-04-02 16:17 被阅读0次

一、结构体知识点:

1、用户自己指定一种数据结构,它称为结构体(structure)。

2、struct 结构体名 是一个类型名,与系统提供的标准类型一样,都可以用来定义变量的类型。

3、表示方法:

(1)struct 结构体名{ 成员表列 };  类型名 成员名;

(2)struct 结构体名{ 成员列表 }变量名表列;

(3)struct { 成员表列 }变量名表列;

4、结构体变量的引用。

不能将一个结构体变量作为一个整体进行输入输出,只能对结构体变量中的各个成员分别进行输入和输出。

结构体变量名.成员名

“.”是成员(分量)运算符,它在所有运算符里最高。

5、结构体数组。

P287 例题11.2。

11.2题目 11.2答案

6、指向结构体类型数据的指针。

“->”指向运算符。

以下三种情况等价:①结构体变量.类型名

②(*p).成员名

③p->成员名

1、指向结构体变量的指针。

struct student stu_1;

struct student *p;

p=&stu_1;

2、指向结构体数组元素的指针。

struct student stu[ ];

struct student *p;

p=stu;

二、用指针处理链表。

1、链表是一种重要的数据结构。动态的进行存储分配的方式。根据需要分配内存空间。

链表举例

(1)链表有一个“头指针”变量。它存放一个地址,该地址指向一个元素。

(2)链表中每一个元素称为“节点”。每个节点包括两部分:用户需要用的实际数据和下一个节点的地址。

(3)最后一个元素不指向其他元素,称为“表尾”。它的地址部分放一个“NULL”(表示“空地址”),链表到此结束。

这种链表的数据结构,必须利用指针变量来实现,即一个节点包括一个指针变量,用来存放下一个地址。

struct student {

int num;

float score;

struct student *next;

};

一个指针类型的成员既可以指向其他类型的结构体数据,也可以指向自己所在的结构体类型的数据。

上面只是定义了一个struct student 类型,并未实际分配存储空间,只有定义了变量才分配内存单元。

2、简单链表。

P295 例题11.7。

完成上面的链表 11.7题目 11.7答案

3、处理动态链表所需的函数。

(1)malloc函数。

函数原型:void *malloc(unsigned int size);

作用:在内存的动态存储区中分配一个长度为size的连续空间。

返回值:是一个分配域的起始地址(类型为void)。未能成功执行则返回空指针。

(2)calloc函数。

函数原型:void *calloc(unsigned n, unsigned size);

作用:在内存的动态存储区中分配n个长度为size的连续空间。

返回值:一个指向分配域起始位置的指针。如果分配成功返回NULL。

用calloc函数可以为一维数组开辟动态存储空间,n为数组元素个数,每个元素长度为size。

(3)free函数。

函数原型:void free(void *p);

作用:释放由p指向的动态存储空间,使这部分内存区能被其他变量使用。p是最近一次调用calloc函数或malloc函数的返回值。free函数无返回值。

\bullet   P297 例题11.8  写一个函数建立一个有三名学生数据的单向动态链表。

4、建立动态链表。

建立链表 对建立链表解释

5、输出链表。

首先要知道链表第一个节点的地址,也就是要知道head的值。然后设一个指针变量p,先指向第一个节点,输出p所指的节点,然后使p后移一个节点,再输出,直到链表的尾节点。

输出链表

6、对链表的删除操作。

从一个动态链表中删去一个节点,并不是真正从内存中把它抹掉,而是把它从链表中分离开来,只要撤销原来的链接关系即可。

删除链表

7、对链表的插入操作。

插入链表

8、对链表综合运用(main函数)。

main函数

三、共用体知识点。

1、需求:使几种不同类型的变量存放到同一段内存单元中。

union 共用体名{

成员表列

}变量表列;

结构体变量所占内存长度是各成员占的内存长度之和,每个成员分别占有其自己的内存单元。

共用体变量所占的内存长度等于最长的成员的长度。

2、同一个内存段可以用来存放几种不同类型的成员,但在每一瞬时只能存放其中一种,而不是同时存放几种。

共用体变量中起作用的成员是最后一次存放的成员,在存入一个新的成员后原有的成员就失去作用。

共用体变量的地址和它的各成员的地址都是同一个地址。

不能对共用体变量名赋值,也不能企图引用变量名来得到一个值,又不能在定义共用体变量时对它初始化。

不能把共用体变量作为函数参数,也不能使函数带回共用体变量,但可以使用指向共用体变量的指针。

共用体类型可以出现在结构体类型中,也可以定义共用体数组,反之也可以。

3、P311 例题11.12。

11.12题目 11.12答案

四、枚举类型。

1、声明枚举类型用enum开头。

(定义1)例如:enum weekday{sun,mon,tue,wed,thu,fri,sat};

声明一个枚举类型 enum weekday,可以用此来定义变量。

例如:enum weekday workday,week_end;

workday和week_end被定义为枚举变量,它们的值只能是sun到sat之一。

(定义二)例如:enum weekday{sun,mon,tue,wed,thu,fri,sat}workday,week_end;

2、说明:

(1)对枚举元素按照常量来处理,故称枚举常量。它们不是变量,不能对它们赋值。

(2)枚举元素作为常量,它们是有值的,按定义的顺序使它们的值为0,1,2......

(3)枚举值可以用来作判断比较。

(4)一个整数不能直接赋值给一个枚举变量。应先强制类型转换才能赋值。

workday=(enum weekday)2; <==> workday=tue;

P313 例题11.13。

11.13题目 11.13答案

五、用typedef命名已有类型。

1、typedef 声明新的类型名来代替已有的类型名。

例如:typedef int INTEGER;

int a; <==> INTEGER a;

2、声明一个新的类型名方法:

step1.先按照定义变量的方法写出定义体(如:int i;)。

step2.将变量名换成新类型名(如:将i换成COUNT)。

step3.在最前面加typedef(如:typedef int COUNT)。

step4.然后可以用新类型名去定义变量。

相关文章

  • 第十一章-结构体与共用体(知识点)

    一、结构体知识点: 1、用户自己指定一种数据结构,它称为结构体(structure)。 2、struct 结构体名...

  • C语言笔记(五)----struct,enum,typedef等

    第十一章 结构体与共用体 1. 定义结构的一般形式: 成员表列由若干个成员组成,每个成员都是该结构的一个组成部分。...

  • C语言学习之十——共用体、枚举类型和typedef

    共用体1.1共用体的概念 :使几个不同的变量共占同一段内存的结构,称为“共用体”类型的结构。1.2 定义共用体类型...

  • 9.结构体与共用体

    1.共用体 共用体的概念 : 使几个不同的变量共占同一段内存的结构称为 “共用体”类型的结构。 定义共用体类型变量...

  • 结构体 联合体 位域

    union 共用体/联合体 结构体和共用体的区别在于:结构体的各个成员会占用不同的内存,互相之间没有影响;而共用体...

  • NDK开发—结构体、共用体与C++基础(三)

    目录 结构体、共用体与C++基础11、结构体字节对齐2、共用体3、C++ 输出函数符号兼容引用字符串C字符串字符串...

  • Day7

    学习内容:结构体、共用体、枚举(1/2)收获: 了解了结构体变量的定义与使用 了解了结构体数组的使用; 了解了结构...

  • 面经---依依短租

    1. 结构体、共用体、类 C++中结构体与类的区别: 结构体中的成员访问权限不声明时候默认是 public 的,而...

  • 王道程序员求职宝典(四)结构体,共用体与枚举

    结构体,共用体与枚举 结构体结构体定义一些特性可继承访问方式构造/析构函数定义递归嵌套初始化结构体位字段整型或枚举...

  • C语言基础 之 共用体类型

    共用体类型 共用体类型的说明和变量定义 共用体类型又称“联合类型”,简称共用体。共用体类型的说明和变量的定义方式与...

网友评论

    本文标题:第十一章-结构体与共用体(知识点)

    本文链接:https://www.haomeiwen.com/subject/gaiauhtx.html