C語言面試篇1:判斷數據大小端存儲

一、前言

本節,我們將學習C語言庫中數據存儲方式,並通過編寫代碼確定當前系統的數據存儲方式。

二、簡介

1.大端模式

大端模式是指數據的高字節保存在內存的低地址中,而數據的低字節保存在內存的高地址中。

2.小端模式

小端模式是指數據的高字節保存在內存的高地址中,而數據的低字節保存在內存的低地址中。

3.爲什麼會有大小端之分?

爲什麼會有大小端模式之分呢?這是因爲在計算機系統中,我們是以字節爲單位的,每個地址單元都對應着一個字節,一個字節爲 8bit。但是在C語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器),另外,對於位數大於 8位的處理器,例如16位或者32位的處理器,由於寄存器寬度大於一個字節,那麼必然存在着一個如何將多個字節安排的問題。因此就導致了大端存儲模式和小端存儲模式。

4.圖例說明

圖中表示數據0x12345678的數據存儲方式。
C語言面試篇1:判斷數據大小端存儲

三、實例

1.指針方式

#include <stdio.h>
int is_big_endian(void)
{
    int val = 0x12345678;
    char data = 0;
    data = ((char*)&val)[0];
    if (0x12 == data)
    {
        return 1;
    }else if(0x78 == data)
    {
        return 0;
    }
}
int main(void)
{
    if (1 == is_big_endian())
    {
        printf("system is large endian!\r\n");
    }else if (0 == is_big_endian())
    {
        printf("system is small endian!\r\n");
    }
    return 0;    
}

執行結果如下:

C語言面試篇1:判斷數據大小端存儲

2.共用體方式

#include <stdio.h>
union udata
{
    int a;
    char b;
}data;
int is_big_endian(void)
{
    data.a = 0x12345678;
    if (0x12 == data.b)
    {
        return 1;
    }else if (0x78 == data.b)
    {
        return 0;
    }
}
int main(void)
{
    if (1 == is_big_endian())
    {
        printf("system is large endian!\r\n");
    }else if (0 == is_big_endian())
    {
        printf("system is small endian!\r\n");
    }
    return 0;    
}

執行結果如下:
C語言面試篇1:判斷數據大小端存儲

四、結語

如您在使用過程中有任何問題,請加QQ羣進一步交流,也可以github提Issue。

QQ交流羣:906015840 (備註:物聯網項目交流)

github倉庫地址:https://github.com/solitary-sand/c

一葉孤沙出品:一沙一世界,一葉一菩提

wechat

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章