日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 嵌入式 > 嵌入式大雜燴
[導讀]通信協(xié)議中的數(shù)據(jù)傳輸、數(shù)組的存儲方式、數(shù)據(jù)的強制轉(zhuǎn)換等這些都會牽涉到大小端問題。 CPU的大端和小端模式很多地方都會用到,但還是有許多朋友不知道,今天暫且普及一下。 一、為什么會有大小端模式之分呢? 因為在計算機系統(tǒng)中,我們是以字節(jié)為單位的,每個



通信協(xié)議中的數(shù)據(jù)傳輸、數(shù)組的存儲方式、數(shù)據(jù)的強制轉(zhuǎn)換等這些都會牽涉到大小端問題。


CPU的大端和小端模式很多地方都會用到,但還是有許多朋友不知道,今天暫且普及一下。

一、為什么會有大小端模式之分呢?


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


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


例如一個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開始存放:

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



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




從上面表格、圖可以看得出來,大小端的差異在于存放順序不同。

在維基百科中還有有一段關于“端的起源”:




三、數(shù)組在大端小端情況下的存儲
以unsigned int value = 0x12345678為例,分別看看在兩種字節(jié)序下其存儲情況,我們可以用unsigned char buf[4]來表示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 高位



不知道大家對數(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)絡)

2.STM32屬于小端模式

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


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


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

開篇說了,實際應用中,大小端應用的地方很多通信協(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))



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



????????????????  END  ????????????????


以上內(nèi)容轉(zhuǎn)自公眾號『strongerHuang』,作者黃工。這里再分享黃工的一些系列文章匯總:

【專欄】STM32CubeMX系列教程

【專欄】μC/OS系列教程

【專欄】CANOpen系列教程



黃工的公眾號還匯總很多軟硬件干貨,推薦關注。 識別下面二維碼即可關注。


長按前往圖中包含的公眾號關注

免責聲明:本文內(nèi)容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構(gòu)授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

由臺達集團于2026年3月29日通過美通社發(fā)布新聞稿《集裝箱式SST直流移動智算中心發(fā)布》中,第3張有誤,已進行替換。特此更正,更新后的全文及圖片如下: 集裝箱式SST直流移動智算中心發(fā)布 臺達、漢騰科技、龍芯中科攜...

關鍵字: 移動 ST 固態(tài)變壓器 CPU

面對AI Agent與Physical AI的浪潮,單純依靠增加GPU或NPU的補丁式方案已難以為繼,CPU架構(gòu)必須進行面向AI的底層重塑。 阿里達摩院發(fā)布的玄鐵C950旗艦處理器,不僅刷新了單核性能紀錄,更通過原生A...

關鍵字: 玄鐵C950 CPU AI 物理AI RISC-V

北京2026年3月27日 /美通社/ -- 當?shù)谑鍖萌珖\動會辦公系統(tǒng)全程穩(wěn)定運行時,當銀行柜員輕點鼠標實現(xiàn)業(yè)務秒級響應時,當大學生刷一卡通順暢進出宿舍、食堂、圖書館時,當新能源汽車充電樁智能調(diào)度、巨災預警系統(tǒng)精準響應...

關鍵字: CPU 指令集 芯片 操作系統(tǒng)

成立三十余年來,Arm一直是芯片行業(yè)特殊的“幕后推手”——不生產(chǎn)一顆芯片,卻定義了全球99%智能手機的底層架構(gòu)。然而,這家長期保持中立的IP授權巨頭,如今正打破自己一手建立的商業(yè)規(guī)則。

關鍵字: ARM CPU 芯片

Arm 首次將其平臺矩陣拓展至量產(chǎn)芯片產(chǎn)品,為業(yè)界提供覆蓋 IP、Arm計算子系統(tǒng) (CSS)及芯片的最廣泛的計算產(chǎn)品選擇。 發(fā)布首款由 Arm 設計的數(shù)據(jù)中心 CPU——Arm AGI CPU,專為代理式AI 基...

關鍵字: ARM CPU 數(shù)據(jù)中心 代理式AI

2026年3月24日,美國加州圣何塞訊——Super Micro Computer, Inc.(NASDAQ:SMCI)作為云端計算、AI/機器學習、存儲和5G/邊緣領域的全方位IT解決方案供應商,宣布推出基于NVIDI...

關鍵字: DCBBS液冷架構(gòu) CPU 存儲

3月24日,由阿里巴巴達摩院主辦的2026玄鐵RISC-V生態(tài)大會在上海舉行。高通、Arteris、Canonical、SHD Group、海爾、中興通訊、全志科技、北京智芯微、南芯科技等全球數(shù)百家產(chǎn)學研機構(gòu)齊聚一堂,分...

關鍵字: RISC-V CPU 算力

Supermicro的NVIDIA Vera Rubin NVL72與HGX Rubin NVL8系統(tǒng)是基于DCBBS液冷架構(gòu)所設計,與NVIDIA Blackwell...

關鍵字: CPU MICRO NVIDIA SUPER

3月24日消息,今日,在上海舉行的2026玄鐵RISC-V生態(tài)大會上,阿里巴巴達摩院發(fā)布新一代旗艦CPU產(chǎn)品玄鐵C950。

關鍵字: RISC-V CPU

March 18, 2026 ---- 根據(jù)TrendForce集邦咨詢最新AI Server研究,在大型云端服務供應商(CSP)加大自研芯片力道的情況下,NVIDIA(英偉達)在GTC 2026大會改為著重各領域的AI...

關鍵字: ASIC GPU CPU
關閉