C語言自定義數據類型詳解(四)——聯合體

好的,接下來我們來學習最后一個自定義數據類型——聯合體。

一、什么是聯合體:

聯合體又叫共用體,用關鍵字union來進行定義。又因為所有的成員變量共用同一段內存空間(關于這一點,我們不久就會加以驗證),所以它是一種比較特殊的自定義類型。

二、聯合體的內存布局:

(1)驗證聯合體成員共用同一塊空間:

我們前面已經提到了說聯合體它的成員變量都是共用同一段內存空間的,我們可以通過下面這個代碼對這一結論加以驗證:

#include<stdio.h>
union Uo
{int a;char i;
};
int main()
{union Uo u;printf("sizeof(u) == %zd\n", sizeof(u));printf("%p\n", &(u.a));printf("%p\n", &(u.i));return 0;
}

運行效果:

?

我們發現對于聯合體u,它的大小是4Byte,且無論是針對它的成員變量a取地址,還是針對它的成員變量i取地址,它的結果都是一樣的

我們可以進一步做一些事情,我們修改變量a的值,然后來觀察成員變量i是否會受影響。因此我們寫出下面這個代碼:

#include<stdio.h>
union Uo
{int a;char i;
};
int main()
{union Uo u;u.a = 0x44332211;//%x是以十六進制打印整數:printf("0x%x\n", u.a);printf("0x%x\n", u.i);return 0;
}

運行結果(注意這里的結果你可能和我不一樣,因為這和機器是小端字節序,還是大端字節序有關系。而博主現在是小端字節序的機器):

?

我們發現對聯合體中某一個成員變量的值進行修改,也會影響到其他的成員變量。這里又進一步佐證了聯合體的成員變量共用同一段內存空間這一事實。

綜上,對于聯合體變量union Uo u來說,它的內存布局是:


(2)聯合體內存大小的計算:

有很多小伙伴在聯合體這里會犯一個錯誤,認為聯合體的大小就是最大成員變量的大小。但是其實不然,就比如說下面這個代碼場景:

#include<stdio.h>
union Uo
{int a;char i[5];
};
int main()
{union Uo u;printf("%zd\n", sizeof(u));return 0;
}

運行結果:

所以關于聯合體的大小:我們認為聯合體的大小至少是最大成員變量的大小。當最大成員變量的大小不是最大對齊數的整數倍時(關于對齊數可以看博主的前面的博客C語言自定義數據類型詳解(二)——結構體類型(下)-CSDN博客)需要進行內存對齊

三、聯合體的應用場景:

我們試想這么一個場景:我們要求設計一些數據類型來存儲圖書布袋襯衫這三個商品的一些屬性。那首先分析這三個商品,它們都有各自以下這些屬性:

圖書:庫存量,價格,書名,作者;

布袋:庫存量,價格,樣式;

襯衫:庫存量,價格,顏色,尺寸;

那據此,你可不可以設計下面這樣的:

struct book
{int _stock;  //庫存float _price;//價格char _bookName[30];//書名char _writer[30];  //作者
};
struct bag
{int _stock;  //庫存float _price;//價格char _style[30];//樣式
};
struct shirt
{int _stock;  //庫存float _price;//價格char color[15];//顏色size_t _size;  //尺寸
};

但是你有沒有覺得這個設計比較冗余,因為庫存量和價格都是這些商品共有的屬性。這在C++,Java里面可以通過繼承的方式來消除這種設計上的冗余,那C語言呢?OK,C語言可以借助聯合體設計出下面這個結構體:

#include<stdio.h>
#include<string.h>
struct commodity
{int _stock;  //庫存float _price;//價格//這里面都是匿名結構體和匿名聯合體哦!union{struct{char _bookName[30];//書名char _writer[30];  //作者} _book;struct{char _style[30];//樣式} _bag;struct{char color[15];//顏色size_t _size;  //尺寸} _shirt;}_item;
};
int main()
{struct commodity com;//注意這里的_writer是char* const的指針(常量指針),所以不能寫作com._item._book._writer = "MoYan";strcpy(com._item._book._writer, "MoYan");printf("The writer of the book is %s\n", com._item._book._writer);return 0;
}

OK,這次的知識分享就到這里了,我們下次再見!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/90811.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/90811.shtml
英文地址,請注明出處:http://en.pswp.cn/web/90811.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

[python][flask]Flask-Login 使用詳解

1. 簡介Flask-Login 是 Flask 的一個擴展&#xff0c;專門用于處理用戶認證相關的功能。它提供了用戶會話管理、登錄/注銷視圖、記住我功能等常見認證需求&#xff0c;讓開發者能夠快速實現安全的用戶認證系統。2. 安裝與基礎配置首先&#xff0c;需要安裝 Flask-Login&#xf…

【WebGPU學習雜記】WebAssembly中的relaxed_madd指令到底做了什么?

relaxed_madd 這條指令到底做了什么核心&#xff1a;relaxed_madd 是一個分量級別 (Component-wise) 的操作 首先&#xff0c;最重要的一點是&#xff1a;v128.relaxed_madd<f32>(a, b, c) 不是矩陣乘法。它是一個在三個向量 a, b, c 之間進行的、逐個分量的、并行的融合…

【全新上線】境內 Docker 鏡像狀態監控

境內 Docker 鏡像狀態監控&#xff1a;您的 Docker 加速伴侶 在當今云計算和容器化技術飛速發展的時代&#xff0c;Docker 已成為開發者不可或缺的工具。然而&#xff0c;對于身處國內的用戶而言&#xff0c;訪問境外 Docker Hub 等鏡像倉庫時常會遭遇網絡延遲和連接不穩定的困…

Visual Studio中部署PaddleOCRv5 (借助ncnn框架)

PaddleOCRv5_ncnn PaddleOCRv5 在Visual Studio中進行圖片OCR檢測&#xff08;ncnn框架open-mobile實現)&#xff0c;嘗試對nihui的ncnn-android-ppocrv5檢測算法的剝離與移植。 本項目Github鏈接如下&#xff1a;PaddleOCRv5_ncnn 寫在前面 本倉庫代碼是基于nihui的ncnn-a…

中級全棧工程師筆試題

解釋ACID特性&#xff0c;如何在node.js中實現事務操作針對React單頁應用&#xff0c;請提供至少5種性能優化方案&#xff0c;并解釋其原理&#xff1a; 減少首屏加載時間優化渲染性能資源加載策略狀態管理優化代碼分割方案 如何防止以下攻擊&#xff1a; JWT令牌挾持Graph QL查…

Windows---動態鏈接庫Dynamic Link Library(.dll)

DLL的“幕后英雄”角色 在Windows操作系統的生態中&#xff0c;有一類文件始終扮演著“幕后英雄”的角色——它們不像.exe文件那樣直接呈現為用戶可見的程序窗口&#xff0c;卻支撐著幾乎所有應用程序的運行&#xff1b;它們不單獨執行&#xff0c;卻承載著系統與軟件的核心功…

深入分析計算機網絡傳輸層和應用層面試題

三、傳輸層面試題&#xff08;Transmission Layer&#xff09;傳輸層位于 OSI 七層模型的第四層&#xff0c;它的核心任務是為兩個主機之間的應用層提供可靠的數據傳輸服務。它不僅承擔了數據的端到端傳輸&#xff0c;而且還實現了諸如差錯檢測、數據流控制、擁塞控制等機制&am…

【RH134 問答題】第 2 章 調度未來任務

目錄crontab 文件中的用戶作業時間格式怎么解釋&#xff1f;如果需要以當前用戶身份計劃周期性作業&#xff0c;在上午 8 點到晚上 9 點之間每兩分鐘一次輸出當前日期和時間&#xff0c;該作業只能在周一到周五運行&#xff0c;周六或周日不能運行。要怎么做&#xff1f;要計劃…

【ee類保研面試】通信類---信息論

25保研er&#xff0c;希望將自己的面試復習分享出來&#xff0c;供大家參考 part0—英語類 part1—通信類 part2—信號類 part3—高數類 part100—self項目準備 文章目錄**面試復習總綱****Chap2: 熵、相對熵和互信息 (Entropy, Relative Entropy, and Mutual Information)****…

vue2+node+express+MongoDB項目安裝啟動啟動

文章目錄 準備環境 安裝MongoDB 安裝 MongoDB Compass(圖形化數據庫管理工具) 安裝 Postman(接口測試工具) 項目結構 配置項目代理 項目啟動 提交項目 生成Access Token 準備環境 默認含有node.js、npm 安裝MongoDB 下載地址:https://www.mongodb.com/try/download/com…

JavaEE初階第十二期:解鎖多線程,從 “單車道” 到 “高速公路” 的編程升級(十)

專欄&#xff1a;JavaEE初階起飛計劃 個人主頁&#xff1a;手握風云 目錄 一、多線程案例 1.1. 定時器 一、多線程案例 1.1. 定時器 定時器是軟件開發的一個重要組件&#xff0c;是一種能夠按照預設的時間間隔或在特定時間點執行某個任務或代碼片段的機制。你可以把它想象成…

EDoF-ToF: extended depth of field time-of-flight imaging解讀, OE 2021

1. 核心問題&#xff1a;iToF相機的“景深”死穴我們之前已經詳細討論過&#xff0c;iToF相機的“景深”&#xff08;有效測量范圍&#xff09;受到光學散焦的嚴重制約。問題根源&#xff1a; 當iToF相機的鏡頭散焦時&#xff0c;來自場景不同深度的光信號會在傳感器像素上發生…

符號引用與直接引用:概念對比與實例解析

符號引用與直接引用&#xff1a;概念對比與實例解析 符號引用和直接引用是Java虛擬機(JVM)中類加載與執行機制的核心概念&#xff0c;理解它們的區別與聯系對于深入掌握Java運行原理至關重要。下面我將從定義、特性、轉換過程到實際應用&#xff0c;通過具體示例全面比較這兩類…

每日一講——Podman

一、概念1、定義與定位Podman&#xff08;Pod Manager&#xff09;是符合OCI標準的容器引擎&#xff0c;用于管理容器、鏡像及Pod&#xff08;多容器組&#xff09;。它無需守護進程&#xff08;Daemonless&#xff09;&#xff0c;直接通過Linux內核功能&#xff08;如命名空間…

Spring Boot DFS、HDFS、AI、PyOD、ECOD、Junit、嵌入式實戰指南

Spring Boot分布式文件系統 以下是一些關于Spring Boot分布式文件系統(DFS)的實現示例和關鍵方法,涵蓋了不同場景和技術的應用。這些示例可以幫助理解如何在Spring Boot中集成DFS(如HDFS、MinIO、FastDFS等)或模擬分布式存儲。 使用Spring Boot集成HDFS 基礎配置 // 配…

解決GoLand運行go程序報錯:Error: Cannot find package xxx 問題

問題描述 一個簡單的go程序&#xff0c;代碼如下 package mainimport "fmt" func main() {// 占位符&#xff0c;和java的String.format用法一樣fmt.Printf("我%d歲&#xff0c;我叫%s", 18, "yexindong") }結構如下當我想要運行時卻報錯 Error:…

Spring MVC設計精粹:源碼級架構解析與實踐指南

文章目錄一、設計哲學&#xff1a;分層與解耦1. 前端控制器模式2. 分層架構設計二、核心組件源碼解析1. DispatcherServlet - 九大組件初始化2. DispatcherServlet - 前端控制器&#xff08;請求處理中樞&#xff09;請求源碼入口&#xff1a;FrameworkServlet#doGet()請求委托…

k8s之控制器詳解

1.deployment&#xff1a;適用于無狀態服務1.功能(1)創建高可用pod&#xff08;2&#xff09;滾動升級/回滾&#xff08;3&#xff09;平滑擴容和縮容2.操作命令&#xff08;1&#xff09;回滾# 回滾到上一個版本 kubectl rollout undo deployment/my-app# 回滾到特定版本&…

.NET Core中的配置系統

傳統配置方式文件Web.config 進行配置。ConfigurationManager類配置。.NET配置系統中支持配置方式文件配置&#xff08;json、xml、ini等&#xff09;注冊表環境變量命令行自定義配置源Json文件配置方式實現步驟&#xff1a;創建一個json文件&#xff0c;把文件設置 為“如果較…

kafka的消費者負載均衡機制

Kafka 的消費者負載均衡機制是保證消息高效消費的核心設計&#xff0c;通過將分區合理分配給消費者組內的消費者&#xff0c;實現并行處理和負載均衡。以下從核心概念、分配策略、重平衡機制等方面詳細講解。一、核心概念理解消費者負載均衡前&#xff0c;需明確三個關鍵概念&a…