chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

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

黃工的嵌入式技術(shù)圈 ? 來源:黃工的嵌入式技術(shù)圈 ? 作者:黃工的嵌入式技術(shù) ? 2020-02-27 16:46 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

因為在計算機系統(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é)合一張圖進行理解:

從上面表格、圖可以看得出來,大小端的差異在于存放順序不同。 在維基百科中還有有一段關(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ù)組進行強制轉(zhuǎn)換成整型數(shù)據(jù)沒有? 如果你要進行強制轉(zhuǎn)換,肯定要考慮大小端問題。 四、大小端誰更好?

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

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

總結(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ù):

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

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

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

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

1.對于16位字數(shù)據(jù)

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

2.對于32位字數(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)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 通信協(xié)議
    +關(guān)注

    關(guān)注

    28

    文章

    1064

    瀏覽量

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

    關(guān)注

    68

    文章

    11186

    瀏覽量

    221207
  • 計算機系統(tǒng)
    +關(guān)注

    關(guān)注

    0

    文章

    292

    瀏覽量

    25122
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    CPU真的有黃金:看完秒

    在大家的印象中,黃金是珠寶、投資品和工業(yè)原料,但很少有人知道,我們每天使用的電腦CPU里竟然也隱藏著這種貴金屬。那為什么芯片會用到黃金,一顆CPU中能有多少純金呢?不依靠專業(yè)設(shè)備能提取出來嗎?
    的頭像 發(fā)表于 08-30 15:41 ?910次閱讀

    請問支持100條 IPSecVPN LAN-LAN模式 的中心設(shè)備有哪些型號?

    支持100條 IPSecVPN LAN-LAN模式 的中心設(shè)備有哪些型號?
    發(fā)表于 08-07 06:34

    低功耗單片機工作模式是怎樣的?看完這篇就懂了!

    主動模式、空閑模式、停機模式和待機模式等,不同模式通過關(guān)閉CPU、外設(shè)時鐘或切斷部分電路供電實現(xiàn)
    的頭像 發(fā)表于 07-14 10:39 ?385次閱讀
    低功耗單片機工作<b class='flag-5'>模式</b>是怎樣的?看完這篇<b class='flag-5'>你</b>就懂了!

    充電接口真的了解嗎?

    USB(Universal Serial Bus,通用串行總線)自1994年誕生以來,已成為我們?nèi)粘I钪胁豢苫蛉钡慕涌跇藴?。從鍵盤、鼠標到手機、充電寶,USB接口無處不在。但知道USB接口也有
    的頭像 發(fā)表于 05-18 17:39 ?2333次閱讀

    一文讀懂:MCX 插頭大小差異帶來的影響與應(yīng)用區(qū)別

    科技的世界里,每一個參數(shù)的細微差別,都像是藏在精密儀器里的悄悄話。MCX 插頭的大小差異,也只有真正它的工程師、技術(shù)人員,才能理解其中的精妙之處。有些情緒,只想說給的人聽;而這些關(guān)于連接與傳輸
    的頭像 發(fā)表于 04-24 18:02 ?556次閱讀
    一文讀懂:MCX 插頭<b class='flag-5'>大小</b>差異帶來的影響與應(yīng)用區(qū)別

    Modbus TCP通信的那些坑!遇到過幾個?

    Modbus TCP通信,需要建立連接,對于S7-200 Smart CPU作為Modbus TCP客戶時,可以通過mbus_client指
    的頭像 發(fā)表于 04-16 17:17 ?918次閱讀
    Modbus TCP通信的那些坑!<b class='flag-5'>你</b>遇到過幾個?

    CLRC663 RF設(shè)計,如何配置 TxN 和 TxP 的單模式?

    我有一個與單 CLRC663 RF 電路設(shè)計有關(guān)的問題。數(shù)據(jù)表提到,通過連接 RxN 和 RxP 并在 rcv_rx_single 寄存器中設(shè)置準差分模式,可以將接收器配置為單模式
    發(fā)表于 03-27 06:22

    AI PC熱潮推動2024年Q4全球客戶CPU市場強勁增長

    根據(jù)知名市場調(diào)查機構(gòu)Jon Peddie Research的最新發(fā)文,2024年第四季度,全球客戶CPU市場經(jīng)歷了一段顯著的增長期,這一趨勢主要得益于AI PC的蓬勃興起。 在過去的一段時間
    的頭像 發(fā)表于 02-12 11:09 ?766次閱讀

    DAC900電流輸出可以直接連接電阻嗎?對電阻的大小有什么要求?

    想問下DAC900電流輸出可以直接連接電阻嗎?對電阻的大小有什么要求。
    發(fā)表于 02-12 06:20

    DeepSeek,優(yōu)可測的!

    深度思考的DeepSeek,對優(yōu)可測做出了評價……
    的頭像 發(fā)表于 02-11 17:32 ?647次閱讀
    DeepSeek,<b class='flag-5'>你</b>是<b class='flag-5'>懂</b>優(yōu)可測的!

    使用ADS1299進行EEG信號采集,在單個通道P新增一個跟隨放大器,電極脫落檢測功能無法實現(xiàn),為什么?

    脫落檢測,一直顯示連接成功,請問這種設(shè)計是否真的無法實現(xiàn)脫落檢測功能?(使用的模式是DC-Lead off)
    發(fā)表于 11-21 07:01

    智己汽車“”智駕方案推出,老司機真的會被取代嗎?

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

    怎么在JAVA中確定線性池大小

    在JAVA中確定線性池大小,分別介紹CPU密集型任務(wù)和I/O密集型任務(wù)及其處理方法。
    的頭像 發(fā)表于 10-24 14:02 ?649次閱讀

    高通推出驍龍8至尊版,集成全球最快的移動CPU

    10月21日,在美國夏威夷高通驍龍峰會期間,高通技術(shù)公司推出了驍龍8至尊版移動平臺,這是迄今為止高通最強大且全球速度最快的移動系統(tǒng)級芯片。我們的旗艦移動平臺現(xiàn)將以“至尊版”命名,向行業(yè)展示其顯著
    的頭像 發(fā)表于 10-22 14:40 ?3143次閱讀
    高通推出驍龍8至尊版,集成全球最快的移動<b class='flag-5'>端</b><b class='flag-5'>CPU</b>

    充電協(xié)議和受電協(xié)議有什么區(qū)別及協(xié)議芯片的應(yīng)用

    隨著手機快充技術(shù)出現(xiàn),傳統(tǒng)的慢充模式已經(jīng)滿足不了人們對充電速度的要求,很多電子產(chǎn)品也已經(jīng)紛紛用上了快充模式。在快充的技術(shù)又區(qū)分充電快充協(xié)議和受電快充協(xié)議。 充電
    的頭像 發(fā)表于 10-17 16:14 ?1871次閱讀
    充電<b class='flag-5'>端</b>協(xié)議和受電<b class='flag-5'>端</b>協(xié)議有什么區(qū)別及協(xié)議芯片的應(yīng)用