通信協議中的數據傳輸、數組的存儲方式、數據的強制轉換等這些都會牽涉到大小端問題。 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
+關注
關注
68文章
10879瀏覽量
212197 -
C語言
+關注
關注
180文章
7608瀏覽量
137126
原文標題:你真的懂CPU大小端模式嗎?
文章出處:【微信號:eet-china,微信公眾號:電子工程專輯】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
智己汽車“端到端”智駕方案推出,老司機真的會被取代嗎?
![智己汽車“<b class='flag-5'>端</b>到<b class='flag-5'>端</b>”智駕方案推出,老司機<b class='flag-5'>真的</b>會被取代嗎?](https://file1.elecfans.com/web2/M00/0B/65/wKgaomchj_GANIIiAARrw8JBsJU414.png)
ZCAN PRO解析的DBC Singal 起始位與XNET解析的起始位不同;解析的信號不符合大端邏輯
非門電路的輸入端電阻模式怎么設置電平狀態
cmos和非門電路的輸入端電阻模式是什么
字節跳動為旗下懂車帝籌措資金
AMC1200采用單端工作模式可以嗎?
2024年Q2客戶端CPU出貨量同比增長10.7%
saas模式的一套智慧工地云平臺源碼,支持多端展示:PC端、大屏端、手機端、平板端
![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>](https://file1.elecfans.com/web2/M00/01/B7/wKgaomax4VCASsTuAAhomeHb7Rs081.png)
用THP210做單端轉差分應用,仿真的波形里怎么總有個尖尖?
失調電壓/補償電壓你真的懂了嗎?
![失調電壓/補償電壓<b class='flag-5'>你</b><b class='flag-5'>真的</b>懂了嗎?](https://file.elecfans.com/web2/M00/20/B3/pYYBAGGfNNmAK-PZAAJsGM5Cgk0227.jpg)
字傳輸不變的3種大小端處理方式
![字傳輸不變的3種大小<b class='flag-5'>端</b>處理方式](https://file1.elecfans.com/web2/M00/C7/86/wKgaomYLbsaARhI-AAAgcY7r28c170.png)
評論