数据结构:共用体+枚举

一、共用体

1.共用体中的所有成员,共享一片内存空间,成员的首地址都相同

2.共用体的大小,取决于共用体中成员大小更大的那个

3.一个成员的数据发生修改,另一个会跟着修改

1.定义

把定义结构体时的struct改成union即可

访问共用体成员与访问结构体成员类似。 变量用.访问,指针用->访问

cs 复制代码
union A
{
    int a;
    char c;
};  //声明共用体类型
union A a1;   //定义了一个共用体变量

2.大小端存储(字节序问题)

小端存储:地址低位存数据低位 (常见的计算机都是小端存储)

大端存储:地址地位存数据高位 (网络通信的数据包一般是大字节序)

2.1使用共同体判断字节序问题

cs 复制代码
#include <stdio.h>
union A
{
    char t1;
    int t2;
};
int main(int argc, const char *argv[])
{
    union A a1;   //栈区
 a1.t2 = 0x12345678;   //0x12数据高位  0x78数据低位
    printf("%#X\n",a1.t1);  //访问共用体中的地址低位
    printf("%p\n",&a1.t1);
    printf("%p\n",&a1.t1+3);
    return 0;
}

2.2使用指针判断字节序问题

cs 复制代码
#include <stdio.h>
int main(int argc, const char *argv[])
{
    int a = 0x12345678;
    char *p = &a; //为了只取a的低地址的数据

    if(*p==0x78)
    {
        printf("小端\n");
    }
    else
    {
        printf("大端\n");
    }

    return 0;
}

二、枚举(enum)

1.定义

cs 复制代码
enum 枚举名
{
    枚举项1,
    枚举项2,
    枚举项3,
    ··· 
    枚举项n,           
};  --->使用enum 枚举名 定义变量

typedef enum 枚举名
{
    枚举项1,
    枚举项2,
    枚举项3,
    ··· 
    枚举项n,           
}新的枚举名;  ---->使用新的枚举名定义变量

2.举例

cs 复制代码
#include <stdio.h>
enum week
{
    Sun,
    Mon,
    Tue,
    Wed=6,
    Thu,
    Fri,
    Sat,
};
int main(int argc, const char *argv[])
{
    int a = Sun;
    //Sun = 90;  枚举项不能被赋值
    printf("%d\n",a);
    printf("%d\n",Mon);
    printf("%d\n",Tue);
    printf("%d\n",Sat);
    return 0;
}

3.使用场景

3.1

cs 复制代码
#include <stdio.h>
enum week
{
    Sun,
    Mon,
    Tue,
    Wed,
    Thu,
    Fri,
    Sat,
};
void week_p(enum week p)
{
    switch(p)
    {
    case Sun:
        printf("p是星期天\n");
        break;
    case Sat:
        printf("p是星期六\n");
        break;
    case Mon:
        printf("p是星期一\n");
        break;
    }
}
int main(int argc, const char *argv[])
{
    week_p(Mon);
    return 0;
}

3.2

cs 复制代码
#include <stdio.h>
#include <string.h>
enum LED{
	LED_1,
	LED_2,
	LED_3,
};
enum LED_CON{
	LED_ON,
	LED_OFF,
};
void inint(enum LED L){
	switch(L){
	case LED_1:
		printf("LED_1初始化成功\n");
		break;
	case LED_2:
		printf("LED_2初始化成功\n");
		break;
	case LED_3:
		printf("LED_3初始化成功\n");
		break;

	}
}
void con(enum LED L,enum LED_CON C){
	switch(L){
	case LED_1:
		switch(C){
		case LED_ON:
			printf("LED_1 打开\n");
			break;
		case LED_OFF:
			printf("LED_1 关闭\n");
			break;
		}
		break;
	case LED_2:
		switch(C){
		case LED_ON:
			printf("LED_2 打开\n");
			break;
		case LED_OFF:
			printf("LED_2 关闭\n");
			break;
		}
			break;
	case LED_3:
		switch(C){
		case LED_ON:
			printf("LED_3 打开\n");
			break;
		case LED_OFF:
			printf("LED_3 关闭\n");
			break;
		}
		break;
	}
	if(L==LED_1 && C==LED_ON)  //这里的LED_1不写成L=="LED_1"
		printf("LED_1 打开\n");
	if(L==0 && C==0)
		printf("LED_1 打开\n");
	//这里的LED_1就相当于一个宏定义
	//define LED_1 0



}
int main(int argc, const char *argv[])
{
	init(LED_1);
    con(LED_1,LED_ON);
    init(LED_2);
    con(LED_2,LED_OFF);
    init(LED_3);
    con(LED_3,LED_ON);
	return 0;
}

//这里的LED_1就相当于一个宏定义
//define LED_1 0

相关推荐
武昌库里写JAVA35 分钟前
【Java】Java面试题笔试
c语言·开发语言·数据结构·算法·二维数组
一休哥助手2 小时前
Redis 五种数据类型及底层数据结构详解
数据结构·数据库·redis
苏宸啊2 小时前
顺序表及其代码实现
数据结构·算法
lin zaixi()2 小时前
贪心思想之——最大子段和问题
数据结构·算法
夜雨翦春韭2 小时前
【代码随想录Day30】贪心算法Part04
java·数据结构·算法·leetcode·贪心算法
一直学习永不止步3 小时前
LeetCode题练习与总结:H 指数--274
java·数据结构·算法·leetcode·数组·排序·计数排序
Amor风信子3 小时前
华为OD机试真题---跳房子II
java·数据结构·算法
Ljubim.te4 小时前
软件设计师——数据结构
数据结构·笔记
_GR5 小时前
每日OJ题_牛客_牛牛冲钻五_模拟_C++_Java
java·数据结构·c++·算法·动态规划
无限大.5 小时前
c语言实例
c语言·数据结构·算法