用C語言程序判斷大小端模式
1.大端模式,是指數(shù)據(jù)的低位保存在內(nèi)存的高地址中,而數(shù)據(jù)的高位,保存在內(nèi)存的低地址中;小端模式相反
2.為什么有大小端之分???
因為在計算機(jī)系統(tǒng)中,存儲是以字節(jié)為單位的,每個地址單元都對應(yīng)著一個字節(jié),一個字節(jié)=8bit。在C語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器)。對于位數(shù)大于8位的處理器,例如16位或者32位的處理器,由于寄存器寬度大于一個字節(jié),如何安排多個字節(jié)的存儲,這就有了大端存儲模式和小端存儲模式
3.各自的優(yōu)勢:
小端模式:強(qiáng)制轉(zhuǎn)換數(shù)據(jù)不需要調(diào)整字節(jié)內(nèi)容,1、2、4字節(jié)的存儲方式一樣。
大端模式:符號位的判定固定為第一個字節(jié),容易判斷正負(fù)。
4.常用的X86結(jié)構(gòu)是小端模式,而KEIL C51則為大端模式。很多的ARM,DSP都為小端模式.
5.C語言判斷大小端模式
方法一:
void IsBigEndian()
{
short int a = 0x1122;//十六進(jìn)制,一個數(shù)值占4位
char b = *(char *)&a; //通過將short(2字節(jié))強(qiáng)制類型轉(zhuǎn)換成char單字節(jié),b指向a的起始字節(jié)(低字節(jié))
if( b == 0x11)//低字節(jié)存的是數(shù)據(jù)的高字節(jié)數(shù)據(jù)
{
//是大端模式
}
else
{
//是小端模式
}
}
方法二:
void IsBigEndian()//原理:聯(lián)合體union的存放順序是所有成員都從低地址開始存放,而且所有成員共享存儲空間
{
union temp
{
short int a;
char b;
}temp;
temp.a = 0x1234;
if( temp.b == 0x12 )//低字節(jié)存的是數(shù)據(jù)的高字節(jié)數(shù)據(jù)
{
//是大端模式
}
else
{
//是小端模式
}
}
在我的機(jī)子上驗證了一下是小端模式
相關(guān)文章
Qt數(shù)據(jù)庫應(yīng)用之實現(xiàn)數(shù)據(jù)分組導(dǎo)出
這篇文章主要為大家詳細(xì)介紹了如何利用Qt實現(xiàn)數(shù)據(jù)庫數(shù)據(jù)分組導(dǎo)出,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)或工作有一定參考價值,需要的可以了解一下2022-06-06C語言+shell實現(xiàn)linux網(wǎng)卡狀態(tài)檢測
這篇文章主要為大家詳細(xì)介紹了C語言+shell實現(xiàn)linux網(wǎng)卡狀態(tài)檢測,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06Visual Studio 2022最新版安裝教程(圖文詳解)
本文主要介紹了Visual Studio 2022最新版安裝教程,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01C語言輸入一個數(shù)判斷是否為素數(shù)的多種方法
素數(shù)是只能被1和它自己本身整除,不能被其他自然數(shù)整除的大于1的正整數(shù),下面這篇文章主要給大家介紹了關(guān)于C語言輸入一個數(shù)判斷是否為素數(shù)的多種方法,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04