day16

目录

[1 联合体的定义和使用](#1 联合体的定义和使用)

[2 联合体的内存布局](#2 联合体的内存布局)

[3 联合体的应用](#3 联合体的应用)


1 联合体的定义和使用

cpp 复制代码
#include <iostream>

using namespace std;

struct DataS
{
	int i;	
	double d;	
	char s[10];	
	
};

/*
	联合体 所有成员共享同一段内存  
		   修改一个成员会影响其他成员
{
*/
union DataU
{
	int i;		//4个字节
	double d;	//8个字节
	char s[10];	//10个字节
	//联合体成员大小由最大的成员决定,因此该联合体的大小是10个字节
};
/*
1、定义和使用分开
union DataU
{
	int i;		//4个字节
	double d;	//8个字节
	char s[10];	//10个字节
	//联合体成员大小由最大的成员决定,因此该联合体的大小是10个字节
};
DataU a,b,c;
2、定义和使用结合
union DataU
{
	int i;		
	double d;	
	char s[10];	
}a,b,c;
3、匿名:不想让别人使用
union
{
	int i;
	double d;
	char s[10];
}a,b,c;
*/
int main()
{
	DataS ds;
	cout << &ds.i << "," << &ds.d << "," << (void*)ds.s << endl;

	DataU du;
	cout << &du.i << "," << &du.d << "," << (void*)du.s << endl;
	return 0;
}

2 联合体的内存布局

cpp 复制代码
#include <iostream>
using namespace std;

union DataU {
    int i;      // 4
    double d;   // 8
    char s[7];  // 7
};

int main() {
    cout << sizeof(DataU) << endl;
    DataU du;
    du.s[0] = 255;      // 11111111
    du.s[1] = 1;        // 00000001
    du.s[2] = 0;        // 00000000
    du.s[3] = 0;        // 00000000
    cout << du.i << endl; // 00000000 00000000 00000001 11111111
    du.i = 256;
    cout << (int)du.s[0] << (int)du.s[1] << (int)du.s[2] << (int)du.s[3] << endl;

    return 0;
}

3 联合体的应用

cpp 复制代码
#include <iostream>

using namespace std;

struct Info
{
	char _name[20];
	int _role;
	union 
	{
		double score;
		char course[20];
	}_sc;

	Info(const char name[20], int role, double s, const char c[20]) {
		strcpy_s(_name, name);
		_role = role;
		if (s > 0) _sc.score = s;
		if (strlen(c) > 0) strcpy_s(_sc.course, c);
	}
};

int main()
{
	Info a[4] = {
		Info("周老师", 0, -1, "CGaGa"),
		Info("周老师", 0, -1, "Python"),
		Info("周同学", 1, 90, ""),
		Info("肖同学", 1, 88, ""),
	};

	for (int i = 0; i < 4; i++)
	{
		if (a[i]._role == 0) {
			cout << a[i]._name << "是一位老师,他是教" << a[i]._sc.course << endl;
		}
		else if (a[i]._role == 1) {
			cout << a[i]._name << "是一位学生,他的分数是" << a[i]._sc.score << endl;
		}
	}
	return 0;
}
相关推荐
华科大胡子8 小时前
AI开发者的网络卡点:Anthropic连接超时
开发语言·php
磊 子9 小时前
STL无序关联容器—unorded_set+unorded_map
开发语言·c++
初夏睡觉9 小时前
数据结构学习之~二叉堆 (P3378 【模版】堆)
数据结构·c++·学习
AI人工智能+电脑小能手9 小时前
【大白话说Java面试题 第84题】【Mysql篇】第14题:为什么用 InnoDB 存储引擎的表建议用整型的自增主键?
java·开发语言·数据库·mysql·面试
云泽80810 小时前
笔试算法 - 链表篇(一):移除、反转、合并、回文判断全解析
数据结构·c++·算法·链表
小poop10 小时前
深入理解指针(中):数组与指针的进阶之旅
c++
YikNjy10 小时前
break和continue
java·开发语言·算法
秋910 小时前
java项目中cpu飙升排查及解决方法
java·开发语言
野生技术架构师10 小时前
牛客网2026最新大厂Java高频面试题精选(附标准答案)
java·开发语言
PH = 710 小时前
JAVA的SPI机制
java·开发语言