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

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

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

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

0BFC_eet_china ? 來(lái)源:電子工程專輯 ? 2020-01-28 15:56 ? 次閱讀

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

因?yàn)樵谟?jì)算機(jī)系統(tǒng)中,我們是以字節(jié)為單位的,每個(gè)地址單元都對(duì)應(yīng)著一個(gè)字節(jié),一個(gè)字節(jié)為8bit。

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

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

對(duì)于大端模式,就將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開始存放:

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

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

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

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

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

2.小端模式下

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

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

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

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

總結(jié):大端小端沒(méi)有誰(shuí)優(yōu)誰(shuí)劣,各自優(yōu)勢(shì)便是對(duì)方劣勢(shì)。

五、常見(jiàn)字節(jié)序

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

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

大端模式:PowerPC、IBM、Sun

小端模式:x86、DEC

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

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

2.STM32屬于小端模式

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

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

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

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

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

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

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

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

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

方法很多種,感興趣的朋友可自行研究。本文就寫到這里,希望對(duì)你有幫助。

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

    關(guān)注

    68

    文章

    10898

    瀏覽量

    212555
  • C語(yǔ)言
    +關(guān)注

    關(guān)注

    180

    文章

    7614

    瀏覽量

    137356

原文標(biāo)題:你真的懂CPU大小端模式嗎?

文章出處:【微信號(hào):eet-china,微信公眾號(hào):電子工程專輯】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    智己汽車“”智駕方案推出,老司機(jī)真的會(huì)被取代嗎?

    與Momenta聯(lián)合打造的IM AD 3.0到端直覺(jué)智能駕駛系統(tǒng),在結(jié)構(gòu)設(shè)計(jì)和決策邏輯上,進(jìn)行了大膽的創(chuàng)新,試圖用“直覺(jué)化”思維模式替代傳統(tǒng)的模塊化系統(tǒng)。 ? IM AD 3.0的技術(shù)架構(gòu):到端直覺(jué)駕駛模型 1.1 模塊化與
    的頭像 發(fā)表于 10-30 09:47 ?325次閱讀
    智己汽車“<b class='flag-5'>端</b>到<b class='flag-5'>端</b>”智駕方案推出,老司機(jī)<b class='flag-5'>真的</b>會(huì)被取代嗎?

    ZCAN PRO解析的DBC Singal 起始位與XNET解析的起始位不同;解析的信號(hào)不符合大端邏輯

    上圖中的DBC文件使用記事本打開,Data_Field信號(hào),起始位為23,長(zhǎng)度為48,大端方式存儲(chǔ);(按照這個(gè)方式存儲(chǔ),明顯已經(jīng)溢出) 上圖為該信號(hào)在ZCANPRO軟件中打開,解析的起始位為23
    發(fā)表于 10-18 13:53

    非門電路的輸入電阻模式怎么設(shè)置電平狀態(tài)

    非門電路的輸入電阻模式設(shè)置電平狀態(tài)的方法主要取決于非門電路的類型(如TTL、CMOS等)以及具體的設(shè)計(jì)需求。以下是一些一般性的指導(dǎo)原則:
    的頭像 發(fā)表于 10-01 17:43 ?594次閱讀

    CMOS和非門電路的輸入電阻模式有什么區(qū)別

    CMOS和非門電路的輸入電阻模式之間存在一些關(guān)鍵的區(qū)別,這些區(qū)別主要體現(xiàn)在電阻的作用、連接方式以及對(duì)電路性能的影響上。
    的頭像 發(fā)表于 10-01 17:32 ?906次閱讀
    CMOS和非門電路的輸入<b class='flag-5'>端</b>電阻<b class='flag-5'>模式</b>有什么區(qū)別

    cmos和非門電路的輸入電阻模式是什么

    CMOS和非門電路的輸入電阻模式涉及多個(gè)方面,包括電阻的作用、連接方式以及如何影響電路性能。以下是對(duì)CMOS和非門電路輸入電阻模式的詳細(xì)分析:
    的頭像 發(fā)表于 10-01 17:30 ?1014次閱讀

    字節(jié)跳動(dòng)為旗下車帝籌措資金

    字節(jié)跳動(dòng)近期正全力為其旗下的汽車信息與服務(wù)平臺(tái)車帝籌集資金,旨在進(jìn)一步鞏固并擴(kuò)大其在汽車領(lǐng)域的市場(chǎng)地位。自去年戰(zhàn)略調(diào)整后,車帝承擔(dān)起整合抖音、今日頭條及西瓜視頻等平臺(tái)汽車內(nèi)容的重任,實(shí)現(xiàn)了內(nèi)容
    的頭像 發(fā)表于 09-26 14:12 ?330次閱讀

    AMC1200采用單工作模式可以嗎?

    想用AMC1200采集外部送入的模擬量,輸出量送給單片機(jī)的AD口,AMC1200采用單工作模式可以?看到的資料用的都是工模輸入
    發(fā)表于 08-29 06:27

    請(qǐng)問(wèn)下st有沒(méi)有32位的大端MCU?怎么找到?

    請(qǐng)問(wèn)下st有沒(méi)有 32位的大端MCU 或者怎么樣才能找到?我一個(gè)個(gè)找看手冊(cè) 太慢了并且都是小
    發(fā)表于 08-14 06:04

    2024年Q2客戶CPU出貨量同比增長(zhǎng)10.7%

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

    saas模式的一套智慧工地云平臺(tái)源碼,支持多端展示:PC、大屏、手機(jī)、平板

    基于微服務(wù)架構(gòu)+Java+Spring Cloud +UniApp +MySql技術(shù)開發(fā)saas模式的一套智慧工地云平臺(tái)源碼,支持多端展示:PC、大屏、手機(jī)、平板
    的頭像 發(fā)表于 08-06 16:41 ?384次閱讀
    saas<b class='flag-5'>模式</b>的一套智慧工地云平臺(tái)源碼,支持多端展示:PC<b class='flag-5'>端</b>、大屏<b class='flag-5'>端</b>、手機(jī)<b class='flag-5'>端</b>、平板<b class='flag-5'>端</b>

    用THP210做單轉(zhuǎn)差分應(yīng)用,仿真的波形里怎么總有個(gè)尖尖?

    用THP210做單轉(zhuǎn)差分應(yīng)用,輸入范圍±2.5V。-3dB大概是5Khz。仿真的波形里怎么總有個(gè)尖尖。當(dāng)-3dB帶寬大的時(shí)候比如100Khz這種,就是很平滑標(biāo)準(zhǔn)的的低通濾波器形狀,截至帶寬越低就越容易出現(xiàn)峰值尖尖。這是啥情況
    發(fā)表于 07-30 06:52

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

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

    請(qǐng)問(wèn)STM32(MDK)默認(rèn)大端還是小?

    STM32(MDK)默認(rèn)大端還是小?
    發(fā)表于 04-30 06:02

    字傳輸不變的3種大小處理方式

    大端,最高字節(jié)存儲(chǔ)在最低的內(nèi)存地址,小則是最低有效字節(jié)存儲(chǔ)在最低的內(nèi)存地址。在Verilog中實(shí)現(xiàn)大端(Big-Endian)和小(Little-Endian)之間的轉(zhuǎn)換通常涉及到
    的頭像 發(fā)表于 04-02 10:32 ?684次閱讀
    字傳輸不變的3種大小<b class='flag-5'>端</b>處理方式

    BUCK電路的CCM模式占空比,知道哪幾種?

    BUCK電路的CCM模式占空比,知道哪幾種? BUCK電路是一種常見(jiàn)的開關(guān)電源拓?fù)浣Y(jié)構(gòu),廣泛應(yīng)用于各種電子設(shè)備中。在控制Buck電路開關(guān)管的導(dǎo)通時(shí)間和關(guān)斷時(shí)間時(shí),需要根據(jù)具體應(yīng)用需求選擇合適
    的頭像 發(fā)表于 02-01 09:08 ?2621次閱讀