字节顺序:高位优先(big-endian)和低位优先(little-endian)
字節(jié)順序:高位優(yōu)先(big-endian)和低位優(yōu)先(little-endian)
網(wǎng)絡(luò)字節(jié)序:?MSB?高字節(jié)前存法 Most Significant Bit?? (Big Edian)?
主機(jī)字節(jié)序:?LSB?低字節(jié)前存法 Lest Significant Bit? (Little Edian)??
字節(jié)順序是指占內(nèi)存多于一個字節(jié)類型的數(shù)據(jù)在內(nèi)存中的存放順序,通常有小端、大端兩種字節(jié)順序。小端字節(jié)序指低字節(jié)數(shù)據(jù)存放在內(nèi)存低地址處,高字節(jié)數(shù)據(jù)存放在內(nèi)存高地址處;大端字節(jié)序是高字節(jié)數(shù)據(jù)存放在低地址處,低字節(jié)數(shù)據(jù)存放在高地址處。基于X86平臺的PC機(jī)是小端字節(jié)序的(原文參考)。在跨系統(tǒng)處理二進(jìn)制數(shù)據(jù)流時,要注意這個問題。我就是在處理++服務(wù)端的BML(Binary Markup Language)二進(jìn)制標(biāo)記數(shù)據(jù)流時碰到了這個問題。
因為現(xiàn)行的計算機(jī)都是以八位一個字節(jié)為存儲單位,那么一個16位的整數(shù),也就是C語言中的short,在內(nèi)存中可能有兩種存儲順序big-endian和litte-endian。考慮一個short整數(shù)0x3132(0x32是低位,0x31是高位),把它賦值給一個short變量,那么它在內(nèi)存中的存儲可能有兩種不同的方式。
對于.net直接用BitConverter的IsLittleEndian屬性來判斷。Int16可以這樣處理:
| 1 2 3 4 | //byte[] buf //startIndex 起始位置 Array.Reverse(buf); //字節(jié)序反轉(zhuǎn) Int16 i = BitConverter.ToInt16(buf, startIndex); |
stackoverflow上有人這樣處理了(參考鏈接),本人未驗證:
| 1 2 3 4 | public static int ToInt32BigEndian(byte[] buf, int i) { ??return (buf[i]<<24) | (buf[i+1]<<16) | (buf[i+2]<<8) | buf[i+3]`; } |
總結(jié)
以上是生活随笔為你收集整理的字节顺序:高位优先(big-endian)和低位优先(little-endian)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 基于VTK的MFC应用程序开发(3)
- 下一篇: 吴恩达机器学习笔记三之逻辑回归