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

 

posted @ 2020-09-28 15:42  ascertain  阅读(1297)  评论(0编辑  收藏  举报