大端存儲
① 大端存儲和小端存儲各自的優缺點是什麼
沒有什麼優缺點.
最好輸入輸出流,程序一致用同一種方式,全用big endian,或 little endian. 省去byte 交換。
② 大端存儲方式和小端存儲方式的區別
採用大小模式對數據進行存放的主要區別在於在存放的位元組順序,大端方式將高位存放在低地址,小端方式將低位存放在高地址。採用大端方式進行數據存放符合人類的正常思維,而採用小端方式進行數據存放利於計算機處理。到目前為止,採用大端或者小端進行數據存放,其孰優孰劣也沒有定論。
③ 大端存儲與小端存儲對存儲數據的要求
大端小端針對多位元組數據存儲時位元組順序而言的。所謂"Little Endian",為INTEL所採用模式,數據的低位元組存放在內存低地址中,高位元組存放在高地址中,即學X86時說的「高高低低」原則。Byte3 Byte2 Byte1 Byte0在內存中對應的是:
Base Address+0 Byte0
Base Address+1 Byte1
Base Address+2 Byte2
Base Address+3 Byte3
所謂"Big Endian" ,為MOTO所採用模式,數據的低位元組存放在內存的高地址,數據的高位元組存放在內存的低地址。Byte3 Byte2 Byte1 Byte0在內存中對應的是:
Base Address+0 Byte3
Base Address+1 Byte2
Base Address+2 Byte1
Base Address+3 Byte0
java使用的是大端序來存儲數據。big—endian:即低位元組的數據存儲在高位內存上,如對於1234,12是高位數據,34為低位數據,則java中的存儲格式應該為12存在內存的低地址,34存在內存的高地址,x86中的存儲格式與之相反。
④ 如何提取大端存儲(Big
必須清楚文件中以大端存儲數據的類型,16、32還是64位。知道了這個,就可以轉換了。轉換方法很多:
1、16位交換HIBYTE()與LOBYTE(),32位交換HIWORD()與LOWORD(),64位前兩者結合
2、調用網路編程函數ntohs(16位)、ntohl(32位)
3、匯編實現,不說了,懂匯編就不會問這個問題了
⑤ 判斷一個機器使用的是大端存儲還是小端存儲
下面的程序可以判斷一台機器是大端存儲還是小端存儲。
[cpp]view plain
#include<stdio.h>
intmain(intargc,char**argv){
//聯合(union)中,所有成員引用的是內存中相同位置,
//由具體成員類型決定了這些位如何被解釋
union{
shorts;
charc[sizeof(short)];
}un;
un.s=0x0102;//16進制數中,02是低序位元組,01是高序位元組
if(sizeof(short)==2){
if(un.c[0]==1&&un.c[1]==2){
printf("big-endian ");
}elseif(un.c[0]==2&&un.c[1]==1){
printf("little-endian ");
}else{
printf("unknow ");
}
}else{
printf("sizeof(short)=%d ",sizeof(short));
}
return0;
}
⑥ 簡述大端存儲法和小端存儲法,並說明信息存儲器對嵌入式設計的影響
摘要 你好,大端排序的好處是接收數據的程序可以優先得到數據的最高位,以便快速反應。
⑦ 大端和小端存儲法是什麼兩者有什麼區別
小端:較高的有效位元組存放在較高的的存儲器地址,較低的有效位元組存放在較低的存儲器地址。
大端:較高的有效位元組存放在較低的存儲器地址,較低的有效位元組存放在較高的存儲器地址。
大端模式就是低位存放在高地址上。高位存放在地址上。
小端模式就是地位存放在低地址上。高位存放在高地址上。
例如,16bit寬的數0x1234在Little-endian模式CPU內存中的存放方式(假設從地址0x4000開始存放)為:
內存地址 0x4000 0x4001
存放內容 0x34 0x12
而在Big-endian模式CPU內存中的存放方式則為:
內存地址 0x4000 0x4001
存放內容 0x12 0x34
⑧ 8051單片機是大端存儲還是小端存儲
大端存儲
16位INT型數據和32位long型數據都是。數據的低位保存在內存的高地址中,數據的高位保存在內存的低地址中.