在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

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

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

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

因為在計算機系統中,我們是以字節為單位的,每個地址單元都對應著一個字節,一個字節為8bit。

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

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

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

二、什么是大端和小端?大端模式:是指數據的高字節保存在內存的低地址中,而數據的低字節保存在內存的高地址中。

小端模式:是指數據的高字節保存在內存的高地址中,而數據的低字節保存在內存的低地址中。

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

地址 小端存放內容 大端存放內容
0x08004003 0x12 0x78
0x08004002 0x34 0x56
0x08004001 0x56 0x34
0x08004000 0x78 0x12

再結合一張圖進行理解:

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

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

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

2.小端模式下

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

不知道大家對數組進行強制轉換成整型數據沒有? 如果你要進行強制轉換,肯定要考慮大小端問題。 四、大小端誰更好?

小端模式:強制轉換數據不需要調整字節內容,1、2、4字節的存儲方式一樣。

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

總結:大端小端沒有誰優誰劣,各自優勢便是對方劣勢。

五、常見字節序

常見的操作系統是小端,通訊協議是大端。

1.常見CPU的字節序

大端模式:PowerPC、IBM、Sun

小端模式:x86、DEC

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

(內容來自網絡

2.STM32屬于小端模式

測試一款MCU屬于大端,還是小端方法很多種,通過打印數據,通過在線調試查看數據:

當然,在MCU的手冊中也有相關說明。

六、大小端轉換

開篇說了,實際應用中,大小端應用的地方很多通信協議、數據存儲等。如果字節序不一致,就需要轉換。

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

1.對于16位字數據

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

2.對于32位字數據

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

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10879

    瀏覽量

    212197
  • C語言
    +關注

    關注

    180

    文章

    7608

    瀏覽量

    137126

原文標題:你真的懂CPU大小端模式嗎?

文章出處:【微信號:eet-china,微信公眾號:電子工程專輯】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

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

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

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

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

    非門電路的輸入電阻模式怎么設置電平狀態

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

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

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

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

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

    字節跳動為旗下車帝籌措資金

    字節跳動近期正全力為其旗下的汽車信息與服務平臺車帝籌集資金,旨在進一步鞏固并擴大其在汽車領域的市場地位。自去年戰略調整后,車帝承擔起整合抖音、今日頭條及西瓜視頻等平臺汽車內容的重任,實現了內容
    的頭像 發表于 09-26 14:12 ?297次閱讀

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

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

    請問下st有沒有32位的大端MCU?怎么找到?

    請問下st有沒有 32位的大端MCU 或者怎么樣才能找到?我一個個找看手冊 太慢了并且都是小
    發表于 08-14 06:04

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

    根據市場調查機構Jon Peddie Research的最新報告,2024年第二季度全球CPU市場呈現出復雜而有趣的趨勢。客戶CPU出貨量同比增長10.7%,顯示出強勁的增長動力,盡管環比略有下降5%。這一增長主要由筆記本
    的頭像 發表于 08-12 15:11 ?558次閱讀

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

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

    用THP210做單轉差分應用,仿真的波形里怎么總有個尖尖?

    用THP210做單轉差分應用,輸入范圍±2.5V。-3dB大概是5Khz。仿真的波形里怎么總有個尖尖。當-3dB帶寬大的時候比如100Khz這種,就是很平滑標準的的低通濾波器形狀,截至帶寬越低就越容易出現峰值尖尖。這是啥情況
    發表于 07-30 06:52

    失調電壓/補償電壓真的懂了嗎?

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

    請問STM32(MDK)默認大端還是小

    STM32(MDK)默認大端還是小
    發表于 04-30 06:02

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

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

    物聯網LWIP之socket編程

    Socket的位置,作為用戶層與其他層的交互媒介。LWIP實現Socket需要操作系統的幫助,如下圖所示。二,Socket編程的基礎知識1.大端模式,小模式(1)
    的頭像 發表于 01-18 08:00 ?1286次閱讀
    物聯網LWIP之socket編程
    主站蜘蛛池模板: 高清色| 国产一级特黄aa大片爽爽| 一级特黄aa大片免费播放视频| 国产精品久久久久乳精品爆| 都市禁忌猎艳风流美妇| 亚洲国产高清人在线| 四虎永久在线免费观看| 色噜噜狠狠狠综合曰曰曰| 女人张开双腿让男人桶完整| 黄视频在线播放| aaaaaa级特色特黄的毛片| 在线观看日本亚洲一区| 第四色成人网| 日不卡| 亚洲jjzzjjzz在线观看| 日本天堂影院在线播放| 免费观看色| cao草棚视频网址成人| 日本欧美强乱视频在线| 成人夜色视频网站在线观看| 一区不卡视频| 超级乱淫视频播放日韩| 日韩dv| 国产成人精品亚洲日本在线观看| 亚洲一区二区三区电影| 日韩免费在线视频| 国产亚洲第一伦理第一区| 天天躁日日躁狠狠躁一级毛片| 黄色录像欧美| 亚洲免费观看视频| 性欧美高清视频| 久久人成| 天天摸夜夜操| 欧美操穴| 亚洲精品成人在线| 日本成本人三级在线观看2018| 国产三级免费观看| 天天干天天添| 中国男女全黄大片一级| 我要看一级大片| 国内黄色一级片|