Linux网络编程之字节序

首先字节序是针对一个一个字节来说的,一个字节以内的话是不涉及字节序的问题的。这里可以类比:古汉语的行文顺序是从右到左的,人们就是从右到左来读的;现代汉语的顺序是从左到右的,人们就是从左到右来读的。
大端:高位字节存在低地址,低位字节存在高地址。
小端:高位字节存在高地址,低位字节存在低地址。
人们规定网络字节序都是大端的,主机字节序可以是小端也可以是大端。在网络中跑的都是大端的字节序,在接收端根据本机的情况决定是否转换。
下面的程序可以用来测试大小端程序:

/*
    字节序:字节在内存中的存储顺序
    小端字节序:数据的高位字节存储在内存的高位地址,低位字节存储在内存的低位地址
    大端字节序:数据的低位字节存储在内存的高位地址,高位字节存储在内存的低位地址
*/

//通过代码检测当前主机的字节序

#include <stdio.h>
int main(){
    union un
    {
        short value;// 两个字节
        char bytes[sizeof(short)];// char[2]
    }test;
    
    test.value = 0x0102;
    if(test.bytes[0] == 1 && test.bytes[1] == 2){
        printf("Big Endian.\n");
    }
    else if (test.bytes[0] == 2 && test.bytes[1] == 1){
        printf("Little Endian.\n");
    }else
    {
        printf("Unknow.\n");
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值