0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

你真的懂CPU大小端模式嗎?

黃工的嵌入式技術(shù)圈 ? 來源:黃工的嵌入式技術(shù)圈 ? 作者:黃工的嵌入式技術(shù) ? 2020-02-27 16:46 ? 次閱讀

通信協(xié)議中的數(shù)據(jù)傳輸、數(shù)組的存儲方式、數(shù)據(jù)的強(qiáng)制轉(zhuǎn)換等這些都會牽涉到大小端問題。 CPU的大端和小端模式很多地方都會用到,但還是有許多朋友不知道,今天暫且普及一下。 一、為什么會有大小端模式之分呢?

因為在計算機(jī)系統(tǒng)中,我們是以字節(jié)為單位的,每個地址單元都對應(yīng)著一個字節(jié),一個字節(jié)為8bit。

但是在C語言中除了8bit的char之外,還有16bit的short型,32bit的int型。另外,對于位數(shù)大于8位的處理器,例如16位或者32位的處理器,由于寄存器寬度大于一個字節(jié),那么必然存在著一個如果將多個字節(jié)安排的問題。因此就導(dǎo)致了大端存儲模式和小端存儲模式。

例如一個16bit的short型x,在內(nèi)存中的地址為0x0010,x的值為0x1122,那么0x11為高字節(jié),0x22為低字節(jié)。

對于大端模式,就將0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,剛好相反。

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

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

假如32位寬(uint32_t)的數(shù)據(jù)0x12345678,從地址0x08004000開始存放:

0x08004003 0x12 0x78
0x08004002 0x34 0x56
0x08004001 0x56 0x34
0x08004000 0x78 0x12
地址 小端存放內(nèi)容 大端存放內(nèi)容

再結(jié)合一張圖進(jìn)行理解:

從上面表格、圖可以看得出來,大小端的差異在于存放順序不同。 在維基百科中還有有一段關(guān)于“端的起源”:

三、數(shù)組在大端小端情況下的存儲以unsigned int value = 0x12345678為例,分別看看在兩種字節(jié)序下其存儲情況,我們可以用unsigned char buf[4]來表示value。 1.大端模式下

高地址 buf[3] 0x78 低位
- buf[2] 0x56 -
- buf[1] 0x34 -
低地址 buf[0] 0x12 高位
地址 數(shù)組 位置

2.小端模式下

高地址 buf[3] 0x12 低位
- buf[2] 0x34 -
- buf[1] 0x56 -
低地址 buf[0] 0x78 高位
地址 數(shù)組 位置

不知道大家對數(shù)組進(jìn)行強(qiáng)制轉(zhuǎn)換成整型數(shù)據(jù)沒有? 如果你要進(jìn)行強(qiáng)制轉(zhuǎn)換,肯定要考慮大小端問題。 四、大小端誰更好?

小端模式:強(qiáng)制轉(zhuǎn)換數(shù)據(jù)不需要調(diào)整字節(jié)內(nèi)容,1、2、4字節(jié)的存儲方式一樣。

大端模式:符號位的判定固定為第一個字節(jié),容易判斷正負(fù)。

總結(jié):大端小端沒有誰優(yōu)誰劣,各自優(yōu)勢便是對方劣勢。

五、常見字節(jié)序

常見的操作系統(tǒng)是小端,通訊協(xié)議是大端。

1.常見CPU的字節(jié)序

大端模式:PowerPC、IBM、Sun

小端模式:x86、DEC

ARM既可以工作在大端模式,也可以工作在小端模式。

(內(nèi)容來自網(wǎng)絡(luò)

2.STM32屬于小端模式

測試一款MCU屬于大端,還是小端方法很多種,通過打印數(shù)據(jù),通過在線調(diào)試查看數(shù)據(jù):

當(dāng)然,在MCU的手冊中也有相關(guān)說明。

六、大小端轉(zhuǎn)換

開篇說了,實際應(yīng)用中,大小端應(yīng)用的地方很多通信協(xié)議、數(shù)據(jù)存儲等。如果字節(jié)序不一致,就需要轉(zhuǎn)換。

只要你理解其中原理(高低順序),轉(zhuǎn)換的方法很多,下面簡單列列兩個。

1.對于16位字?jǐn)?shù)據(jù)

#define BigtoLittle16(A) (( ((uint16)(A) & 0xff00) >> 8) | (( (uint16)(A) & 0x00ff) << 8))

2.對于32位字?jǐn)?shù)據(jù)

#define BigtoLittle32(A) ((( (uint32)(A) & 0xff000000) >> 24) | (( (uint32)(A) & 0x00ff0000) >> 8) | (( (uint32)(A) & 0x0000ff00) << 8) | (( (uint32)(A) & 0x000000ff) << 24))

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 通信協(xié)議
    +關(guān)注

    關(guān)注

    28

    文章

    808

    瀏覽量

    40118
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10698

    瀏覽量

    209324
  • 計算機(jī)系統(tǒng)

    關(guān)注

    0

    文章

    263

    瀏覽量

    24012
收藏 人收藏

    評論

    相關(guān)推薦

    2024年Q2客戶CPU出貨量同比增長10.7%

    根據(jù)市場調(diào)查機(jī)構(gòu)Jon Peddie Research的最新報告,2024年第二季度全球CPU市場呈現(xiàn)出復(fù)雜而有趣的趨勢??蛻?b class='flag-5'>端CPU出貨量同比增長10.7%,顯示出強(qiáng)勁的增長動力,盡管環(huán)比略有下降5%。這一增長主要由筆記本
    的頭像 發(fā)表于 08-12 15:11 ?370次閱讀

    失調(diào)電壓/補(bǔ)償電壓真的懂了嗎?

    一、概念理解輸入失調(diào)電壓:當(dāng)運(yùn)放連接模式為跟隨器時,同相接GND,輸出并不會輸出GND,根據(jù)不同運(yùn)放參數(shù)會有微弱電壓輸出,這個參數(shù)就叫做輸入失調(diào)電壓。理想運(yùn)放:理想運(yùn)放連接為跟隨器模式,并將
    的頭像 發(fā)表于 07-05 08:11 ?458次閱讀
    失調(diào)電壓/補(bǔ)償電壓<b class='flag-5'>你</b><b class='flag-5'>真的</b>懂了嗎?

    真的了解駐波比嗎?到底什么是電壓駐波比?

    真的了解駐波比嗎?到底什么是電壓駐波比?在很長一段時間內(nèi),小編對駐波比的了解僅限于這樣一個概念:它是一個用于描述波反射大小的物理量,取值范圍[1, ∞],值越小,就表示反射越小,值越大
    的頭像 發(fā)表于 05-29 14:27 ?2089次閱讀
    <b class='flag-5'>你</b><b class='flag-5'>真的</b>了解駐波比嗎?到底什么是電壓駐波比?

    STM8L內(nèi)存存儲上有辦法設(shè)置大小嗎?

    我想知道STM8L內(nèi)存存儲上有辦法設(shè)置大小嗎?
    發(fā)表于 04-17 08:22

    如何估算S7-1500 CPU的裝載存儲區(qū)在SIMATIC存儲卡上的大小?

    S7-1500 CPU 的裝載存儲區(qū)在 SIMATIC 存儲卡上。根據(jù)以下操作步驟可以確定用戶程序所需要的存儲區(qū)的大小以便確定所需存儲卡的大小。
    的頭像 發(fā)表于 01-29 10:00 ?745次閱讀
    如何估算S7-1500 <b class='flag-5'>CPU</b>的裝載存儲區(qū)在SIMATIC存儲卡上的<b class='flag-5'>大小</b>?

    求助,請問STM32的FSMC可以配置大小嗎?

    STM32的FSMC可以配置大小么。
    發(fā)表于 01-17 08:22

    RFID和NFC之間的那些事兒,真的了解嗎?

    RFID和NFC之間的那些事兒,真的了解嗎?
    的頭像 發(fā)表于 12-15 09:38 ?1033次閱讀
    RFID和NFC之間的那些事兒,<b class='flag-5'>你</b><b class='flag-5'>真的</b>了解嗎?

    真的網(wǎng)絡(luò)安全嗎?密鑰的分配解析

    A 和 B 都是 KDC 的登記用戶,A 和 B 在 KDC 登記時就已經(jīng)在 KDC 的服務(wù)器上安裝了各自和 KDC 進(jìn)行通信的主密鑰(master key) 的 KA 和 KB,下面統(tǒng)稱主密鑰為密鑰。
    發(fā)表于 12-13 10:31 ?782次閱讀
    <b class='flag-5'>你</b><b class='flag-5'>真的</b><b class='flag-5'>懂</b>網(wǎng)絡(luò)安全嗎?密鑰的分配解析

    肖特基二極管,真的用對了嗎?

    肖特基二極管,真的用對了嗎?
    的頭像 發(fā)表于 12-07 14:27 ?431次閱讀
    肖特基二極管,<b class='flag-5'>你</b><b class='flag-5'>真的</b>用對了嗎?

    作為射頻工程師,真的會用“dB”?

    作為射頻工程師,真的會用“dB”?
    的頭像 發(fā)表于 12-06 14:51 ?429次閱讀
    作為射頻工程師,<b class='flag-5'>你</b><b class='flag-5'>真的</b>會用“dB”?

    請問如何配置STM32的FSMC的大端模式模式

    請問如何配置STM32的FSMC的大端模式模式?還是硬件確定好了的不能修改?
    發(fā)表于 11-07 15:15

    STM32中的FLASH數(shù)據(jù)是大端模式還是小模式?

    怎么判斷STM32的FLASH數(shù)據(jù)是大端模式還是小模式
    發(fā)表于 10-13 07:21

    數(shù)據(jù)存儲中的大小指是什么意思?

    數(shù)據(jù)存儲中的大小指是什么意思
    發(fā)表于 10-13 06:20

    iar編譯器是大端模式還是小模式的?

    iar編譯器是大端模式還是小模式
    發(fā)表于 09-25 08:00

    keil怎么設(shè)置大端和小模式?

    keil怎么設(shè)置大端和小模式,用于stm32
    發(fā)表于 09-21 07:46