欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言詳細分析講解struct與union使用方法

 更新時間:2022年04月20日 17:04:40   作者:清風(fēng)自在?流水潺潺  
最近開始自學(xué)C語言,從最基礎(chǔ)部分的開始學(xué)起。今天看書的時候注意到了struct和union似乎很像,除了名字不同,看起來幾乎沒有區(qū)別。<BR>既然C中定義了struct和union兩個關(guān)鍵字,那么它們肯定是有區(qū)別的,在查了一些資料之后我來總結(jié)一下他們的使用

一、struct 的小秘密

C語言中的 struct 可以看作變量的集合

struct 的問題:空結(jié)構(gòu)體占用多大內(nèi)存?下面編寫程序看一下吧:

#include <stdio.h>
 
struct TS
{
 
};
 
int main()
{
    struct TS t1;
    struct TS t2;
    
    printf("sizeof(struct TS) = %d\n", sizeof(struct TS));
    printf("sizeof(t1) = %d, &t1 = %p\n", sizeof(t1), &t1);
    printf("sizeof(t2) = %d, &t2 = %p\n", sizeof(t2), &t2);
    
    return 0;
}

下面為輸出結(jié)果,可以看到在 gcc 編譯器中空結(jié)構(gòu)體的大小就為0。

二、結(jié)構(gòu)體與柔性數(shù)組

  • 柔性數(shù)組即數(shù)組大小待定的數(shù)組
  • C 語言中可以由結(jié)構(gòu)體產(chǎn)生柔性數(shù)組
  • C 語言中結(jié)構(gòu)體的最后一個元素可以是大小未知的數(shù)組

思考一下,下面的語句所占內(nèi)存空間為多少呢,沒錯,就是 4。

SoftArray 中的 array 僅是一個待使用的標(biāo)識符,不占用存儲空間。

下面看一段柔型數(shù)組使用的代碼:

#include<stdio.h>
#include<malloc.h>
 
struct SoftArray
{
    int len;
    int array[];
};
 
struct SoftArray* create_soft_array(int size)
{
    struct SoftArray* ret = NULL;
    
    if(size > 0)
    {
        ret = (struct SoftArray*)malloc(sizeof(struct SoftArray) + sizeof(int) * size);
        
        ret->len = size;
    }
    return ret;
}
 
void delete_soft_array(struct SoftArray* sa)
{
    free(sa);
}
 
void func(struct SoftArray* sa)
{
    int i = 0;
    
    if(NULL != sa)
    {
        for(i = 0; i < sa->len; i++)
        {
            sa->array[i] = i + 1;
        }
    }
}
 
int main()
{
    int i = 0;
    struct SoftArray* sa = create_soft_array(10);
    
    func(sa);
    
    for(i = 0; i < sa->len; i++)
    {
        printf("%d\n",sa->array[i]);
    }
    
    delete_soft_array(sa);
    
    return 0;
}

下面為輸出結(jié)果:

雖然 array[ ] 數(shù)組在定義的時候沒有指定大小,但是可以在后面使用 malloc 函數(shù)來指定大小。柔性數(shù)組的好處就是 func() 函數(shù)有一個指向柔性數(shù)組的合法指針就行,不用傳遞要處理的數(shù)組大小。

三、C語言中的 union

  • C語言中的 union 在語法上與 struct 相似
  • union 只分配最大成員的空間,所有成員共享這個空間

如下:

union 的使用受系統(tǒng)大小端的影響

如下,就是定義的字面量常數(shù) i 在大小端的存儲位置:

小端模式下地址值存儲低位數(shù)據(jù),大段模式下低地址存儲高位數(shù)據(jù)。

下面編寫程序來判斷一下系統(tǒng)的大小端:

#include <stdio.h>
 
int system_mode()
{
    union SM
    {
        int i;
        char c;
    };
 
    union SM sm;
    
    sm.i = 1;
    
    return sm.c;
}
 
 
int main()
{
    printf("System Mode: %d\n", system_mode());
    return 0;
}

下面為輸出結(jié)果:

所以說我的電腦系統(tǒng)是小端

四、小結(jié)

  • struct 中的每個數(shù)據(jù)成員有獨立的存儲空間
  • struct 可以通過最后的數(shù)組標(biāo)識符產(chǎn)生柔性數(shù)組
  • union 中的所有數(shù)據(jù)成員共享同一個存儲空間
  • union 的使用會受到系統(tǒng)大小端的影響

到此這篇關(guān)于C語言詳細分析講解struct與union使用方法的文章就介紹到這了,更多相關(guān)C語言 struct與union內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式

    C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式

    這篇文章主要為大家詳細介紹了C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C++ 反射機制詳解及實例代碼

    C++ 反射機制詳解及實例代碼

    這篇文章主要介紹了C++ 反射機制詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • C語言實現(xiàn)繪制繞線畫的示例代碼

    C語言實現(xiàn)繪制繞線畫的示例代碼

    繞線畫簡單點來說,就是在木板上釘一圈釘子,通過繞線進行構(gòu)圖,最終呈現(xiàn)出一幅圖像。本文將用C語言實現(xiàn)這一效果,感興趣的小伙伴可以嘗試一下
    2022-11-11
  • OpenCV mask的作用及如何制作掩模mask

    OpenCV mask的作用及如何制作掩模mask

    mask 不是馬斯克,是掩膜,可以用來遮蓋非感興趣區(qū),突出感興趣區(qū),使得圖像處理只專注于ROI部分,OpenCV中的很多函數(shù)用到mask,mask是什么?怎么制作一個mask?本文給大家分享OpenCV mask的作用及如何制作掩模mask,感興趣的朋友一起看看吧
    2023-02-02
  • C語言冒泡排序算實現(xiàn)代碼

    C語言冒泡排序算實現(xiàn)代碼

    本文主要介紹C語言冒泡排序算法,這里給大家舉例說明冒泡排序的思想,并附有代碼示例,有需要的小伙伴可以參考下
    2016-07-07
  • Visual Studio Code (vscode) 配置 C / C++ 環(huán)境的流程

    Visual Studio Code (vscode) 配置 C / C++ 環(huán)境的流程

    這篇文章主要介紹了Visual Studio Code (vscode) 配置 C / C++ 環(huán)境的流程,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • C語言實現(xiàn)繪制LoveBeat愛心曲線的示例代碼

    C語言實現(xiàn)繪制LoveBeat愛心曲線的示例代碼

    這篇文章主要為大家詳細介紹了如何溧陽C語言實現(xiàn)繪制LoveBeat愛心曲線,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-03-03
  • C++ 多態(tài)性虛函數(shù)和動態(tài)綁定學(xué)習(xí)筆記

    C++ 多態(tài)性虛函數(shù)和動態(tài)綁定學(xué)習(xí)筆記

    這篇文章主要為大家介紹了C++ 多態(tài)性虛函數(shù)和動態(tài)綁定學(xué)習(xí)筆記,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • C++ 約瑟夫環(huán)的實例代碼

    C++ 約瑟夫環(huán)的實例代碼

    這篇文章主要介紹了C++ 約瑟夫環(huán)的實例代碼的相關(guān)資料,希望通過本文能幫助到大家,實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-10-10
  • C++或Go求矩陣?yán)锏膷u嶼的數(shù)量詳解

    C++或Go求矩陣?yán)锏膷u嶼的數(shù)量詳解

    這篇文章主要介紹了C++和go實現(xiàn)LeetCode(200.島嶼的數(shù)量),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09

最新評論