1. 程式人生 > >小端大端

小端大端

spa acm 計算 using clu 習慣 最小 結合 如果

一:什麽是大小端

大端模式,是指數據的高字節保存在內存的低地址中,而數據的低字節保存在內存的高地址中,這樣的存儲模式有點兒類似於把數據當作字符串順序處理:地址由小向大增加,而數據從高位往低位放;這和我們的閱讀習慣一致。 小端模式,是指數據的高字節保存在內存的高地址中,而數據的低字節保存在內存的低地址中,這種存儲模式將地址的高低和數據位權有效地結合起來,高地址部分權值高,低地址部分權值低。 口訣:大相反(低位存高位),小相同(低位存低位),叉八六(X86計算機),必小端。 舉例:假如一個int類型數,十六進制(就是給人看的)表示為:0x0026F800 那麽,如果是小端機器,它在內存中就是:00F82600 (上面的低字節還是在低地址) 內存中地址在這種表示法從左往右由低地址到高地址。 如果是大端機器,它在內存中就是 :0026F800 (所見即所得) (上面的低字節存到了高地址) 大小端是以字節為單位的,因為內存中最小單元就是字節。 技術分享
#include <stdio.h>  
  
typedef union un{   
 int i;  
 char ch[2];  
} un;   
  
int main()  
{  
    un u;  
    u.ch[0] = 10;   
    u.ch[1] = 1;  
  
    printf("%d", (short)u.i);   
  
    return 0;  
}  
技術分享 結果為:266 解析: 10 相當於 0000 1010 低地址 1 相當於 0000 0001 高地址 如果是小端模式,低地址存放高位,高地址存放低位,那麽該值按照正常順序書寫就是: 0000 0001 0000 1010,結果為266。 由於X86都是小端,所以在計算機上運行輸出266;

一個聯合體題,不涉及大小端

技術分享
#include<iostream>  
#include <string.h>  
#include <malloc.h>  
#include <stdio.h>  
#include <stdlib.h>  
#include <memory.h>  
using namespace std;  
  
  
typedef struct  AA    
{  
    int b1:5;  
    int b2:2;  
}AA;  
  
int main()  
{  
    AA aa;   
    char cc[100];  
    strcpy(cc,"0123456789abcdefghijklmnopqrstuvwxyz");  
    memcpy(&aa,cc,sizeof(AA));  
    cout << aa.b1 <<endl;  
   cout << aa.b2 <<endl;  
}  
技術分享

這個題在位域的博客中說過http://www.cnblogs.com/13224ACMer/p/6298764.html

小端大端