溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

C語言面試篇1:判斷數(shù)據(jù)大小端存儲(chǔ)

發(fā)布時(shí)間:2020-07-10 15:15:07 來源:網(wǎng)絡(luò) 閱讀:226 作者:一葉孤沙 欄目:編程語言

一、前言

本節(jié),我們將學(xué)習(xí)C語言庫(kù)中數(shù)據(jù)存儲(chǔ)方式,并通過編寫代碼確定當(dāng)前系統(tǒng)的數(shù)據(jù)存儲(chǔ)方式。

二、簡(jiǎn)介

1.大端模式

大端模式是指數(shù)據(jù)的高字節(jié)保存在內(nèi)存的低地址中,而數(shù)據(jù)的低字節(jié)保存在內(nèi)存的高地址中。

2.小端模式

小端模式是指數(shù)據(jù)的高字節(jié)保存在內(nèi)存的高地址中,而數(shù)據(jù)的低字節(jié)保存在內(nèi)存的低地址中。

3.為什么會(huì)有大小端之分?

為什么會(huì)有大小端模式之分呢?這是因?yàn)樵谟?jì)算機(jī)系統(tǒng)中,我們是以字節(jié)為單位的,每個(gè)地址單元都對(duì)應(yīng)著一個(gè)字節(jié),一個(gè)字節(jié)為 8bit。但是在C語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器),另外,對(duì)于位數(shù)大于 8位的處理器,例如16位或者32位的處理器,由于寄存器寬度大于一個(gè)字節(jié),那么必然存在著一個(gè)如何將多個(gè)字節(jié)安排的問題。因此就導(dǎo)致了大端存儲(chǔ)模式和小端存儲(chǔ)模式。

4.圖例說明

圖中表示數(shù)據(jù)0x12345678的數(shù)據(jù)存儲(chǔ)方式。
C語言面試篇1:判斷數(shù)據(jù)大小端存儲(chǔ)

三、實(shí)例

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;????
}

執(zhí)行結(jié)果如下:

C語言面試篇1:判斷數(shù)據(jù)大小端存儲(chǔ)

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;????
}

執(zhí)行結(jié)果如下:
C語言面試篇1:判斷數(shù)據(jù)大小端存儲(chǔ)

四、結(jié)語

如您在使用過程中有任何問題,請(qǐng)加QQ群進(jìn)一步交流,也可以github提Issue。

QQ交流群:906015840 (備注:物聯(lián)網(wǎng)項(xiàng)目交流)

github倉(cāng)庫(kù)地址:https://github.com/solitary-sand/c

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

C語言面試篇1:判斷數(shù)據(jù)大小端存儲(chǔ)

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI