Linux 字節序


 

字節序不是由操作系統決定的,而是由cpu架構決定的,比如 x86 的是 little endian,而 PPC (PowerPC) 是big endian。 所以跑在 x86 上的 linux/windows 都是小端,而跑在 PPC 上的linux則是大端。 (PS: 實際上 PowerPC 是即支持大端也支持小端,但是由於歷史原因默認用大端)

 

  1. 字節序分為大端字節序(big endian)和小端字節序(little endian)
  2. 大端字節序:一個整數的高位字節(23-31bit)存儲在內存的低地址處,低位字節(0-7bit)存儲在內存的高地址處。
  3. 小端字節序:一個整數的高位字節(23-31bit)存儲在內存的高地址處,低位字節(0-7bit)存儲在內存的低地址處。

 

#include<stdio.h> int main() { union { short value; char union_bytes[sizeof(short)]; }test; test.value = 0x0102; if((test.union_bytes[0]==1)&&(test.union_bytes[1]==2)) { printf("big endian\n");
 } else if((test.union_bytes[0]==2)&&(test.union_bytes[1]==1)) { printf("little endian\n");
 } else { printf("unkown...\n");
 } }

 

 

 

 

#include <stdio.h> int main(int argc, char *argv[]) { unsigned int a = 0x12345678; unsigned char *p = (unsigned char *)&a; //只取一個字節 if(0x12 == *p){ printf("Big-Endian\n");
        }else if(0x78 == *p){ printf("Little-Endian\n");
 } return 0; }

 

 

#include <stdio.h> #include <arpa/inet.h> int main(int argc, char *argv[]) { int a = 0x01020304; short int b = 0x0102; printf("htonl(0x%08x) = 0x%08x\n", a, htonl(a));
        printf("htons(0x%04x) = 0x%04x\n", b, htons(b));
 return 0; }

 

htonl: 將主機的無符號長整形數轉換成網絡字節順序。 htons: 將一個無符號短整型數值轉換為網絡字節序,即大端模式(big-endian)

 

 

 

 

https://blog.csdn.net/tennysonsky/article/details/45045549

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM