IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 结构体,枚举,联合的详细讲解及有关面试体的分析 -> 正文阅读

[数据结构与算法]结构体,枚举,联合的详细讲解及有关面试体的分析

结构体

介绍:

结构是一些值的集合,这些值称为成员变量。结构的每个成员可以是不同类型的变量

声明:

struct Stu
{
char name[20];//名字
int age;//年龄
char sex[5];//性别
char id[20];//学号
}//分号不能丢

2.特殊的声明

//匿名结构体类型
struct
{
int a;
char b;
float c;
}x;
struct
{
int a;
char b;
float c;
}a[20], *p;

编译器认为这两个结构体是不一样的

typedef的使用

typedef struct Node
{
int data;
struct Node* next;
}Node;//将struct Node类型重命名为Node

结构体的应用

  1. 存储对应的信息(比如学生)
  2. 用来实现链表等数据结构
//链表
struct Node
{
int data;
struct Node* next;//指向下一个结构体
};

结构体变量初始化

struct Stu //类型声明
{
char name[15];//名字
int age; //年龄
};
struct Stu s = {"zhangsan", 20};//初始化

结构体的内存对齐(热门考点)

对齐规则

  1. 第一个成员在与结构体变量偏移量为0的地址处。//第一个直接放在初始位置
  2. 其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。
    对齐数 = 编译器默认的一个对齐数 与 该成员大小的较小值。
    VS中默认的值为8
  3. 结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。
  4. 如果嵌套了结构体的情况,嵌套的结构体对齐到自己的最大对齐数的整数倍处,结构体的整
    体大小就是所有最大对齐数(含嵌套结构体的对齐数)的整数倍。

计算

例:

truct S3
{
double d;//8  默认对齐数是8   最小值是8  ,所以d占了8个字节
char c;//1    默认对齐数是8   最小值是1  ,所以c占了1个字节
int i;//4     默认对齐数是8   最小值是4  ,所以i占了4个字节
};                                               //总共13个字节,但是*结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。*,所以sizeof(struct S3)为8*2=16.
printf("%d\n", sizeof(struct S3));//16
struct S2
{
char c1;
char c2;
int i;
};
printf("%d\n", sizeof(struct S2));//同理:sizeof(struct S2)为12

嵌套了结构体的情况:

struct S3
{
double d;
char c;
int i;
};
struct S4
{
char c1;
struct S3 s3;//对齐数为自己结构体的最大对齐数:8
double d;
};
printf("%d\n", sizeof(struct S4));//32

结构体传参最好传地址

位段

  1. 位段的成员可以是 int unsigned int signed int 或者是 char (属于整形家族)类型
  2. 位段的空间上是按照需要以4个字节( int )或者1个字节( char )的方式来开辟的。
  3. 位段涉及很多不确定因素,位段是不跨平台的,注重可移植的程序应该避免使用位段。
//一个例子
struct S
{
1字节
char a:3;//a只占3个比特位,剩5比特位
char b:4;//b占4bite,剩1bite
char c:5;//剩余不足,再创造一个bite
char d:4;
};//总共3个字节的大小

位段内存的开辟

在这里插入图片描述

位段的优点和缺点

缺点:

  1. int 位段被当成有符号数还是无符号数是不确定的。
  2. 位段中最大位的数目不能确定。(16位机器最大16,32位机器最大32,写成27,在16位机
    器会出问题。
  3. 位段中的成员在内存中从左向右分配,还是从右向左分配标准尚未定义。
  4. 当一个结构包含两个位段,第二个位段成员比较大,无法容纳于第一个位段剩余的位时,是
    舍弃剩余的位还是利用,这是不确定的
    优点:

能节省空间
例:
在这里插入图片描述

枚举

enum option
{
	EXIT,//0(不赋值从0开始)
	ADD,//1
	DEL,//2
	SEARCH,//3
	MODIFY,//4
	SHOW,//5
	CLEAR,//6
	SORT//7
};

枚举的优点:

  1. 增加代码的可读性和可维护性
  2. 和#define定义的标识符比较枚举有类型检查,更加严谨。
  3. 防止了命名污染(封装)
  4. 便于调试
  5. 使用方便,一次可以定义多个常量

联合(共用体)

联合也是一种特殊的自定义类型
这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间(所以联合也叫共用体)。

//联合类型的声明
union Un
{
char c;
int i;
};
//联合变量的定义
union Un un;
//计算联合变量的大小
printf("%d\n", sizeof(un));//4

联合的特点

联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小(因为
联合至少得有能力保存最大的那个成员)。

面试题:

判断当前计算机的大小端存储

方法一:

int ifnot()
{
	int a=1;
	return *(char*)a;
}//假如是小段则返回1,大段则返回0

方法二:(使用联合)

int ifnot()
{
	union
	{
		char a;
		int b;
	}arr;
	arr.b=1;
	return arr.a;
}

联合大小的计算

  1. 联合的大小至少是最大成员的大小。
  2. 当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。
    例:
union Un1
{
char c[5];
int i;
};
union Un2
{
short c[7];
int i;
};
//下面输出的结果是什么?
printf("%d\n", sizeof(union Un1));
printf("%d\n", sizeof(union Un2));

输出结果为:8 16

总结

不管是结构体,枚举还是联合,都是将一些相关联的信息一起存储起来,一起关联起来,使我们在使用的时候可以将相关联的信息一起提出。

不管是结构体,枚举还是联合的内存计算规则也是为了更好的取出数据,使用数据的。

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-01-24 11:09:15  更:2022-01-24 11:09:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:44:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码