C++大小端字节序

· 大小端字节序

    1.  小端字节序,即为低序字节存储在起始位置,比如在内存中,short a=0x0102,则这个变量如果在字符串中,则变成c[0]=1,c[1]=2

    2.  大端字节序,即为高序字节存储在起始位置,比如在内存中,short a=0x0102,则这个变量如果在字符串中,则变成c[0]=1,c[1]=2


· 如何判断大小端字节序

    我们可以使用共用体来实现上面的功能,代码如下:

#include "unp.h"
  
int main(int argc,char** argv)
{
    union{
        short s;
        char c[sizeof(short)];
    }un;
    un.s = 0x0102;
    printf("%s: ","Ubuntu18l.04");
    if(sizeof(short) == 2){
        if(un.c[0] == 1 && un.c[1] == 2)
            printf("big-endian\n");
        else if(un.c[0] == 2 && un.c[1] == 1)
            printf("little-endian\n");
        else
            printf("unknown\n");
    }else
        printf("sizeof(short) = %d\n",sizeof(short));

    exit(0);
}

    实现的结果如下:

little-endian


· 大小端字节序的问题

    (1) 发送协议栈和接受协议栈必须就这些多字节段各个字节的传送顺序达成一致。网际协议使用大端字节序来传送这些多字节整数。函数如下:

    #include <netinet/in.h>
    uint16_t htons(uint16_t host16bitvalue);
    uint32_t htonl(uint32_t host32bitvalue);
    uint16_t ntohs(uint16_t net16bitvalue);
    uint32_t ntohl(uint32_t net32bitvalue);

    (2) 当服务器和客户端的字节序不一样的时候,可能会出现这样的情况,当服务器向客户端传输遗传数字的时候,客户端解析出来的就可能不是这个数。比如下面:    

#include "stdafx.h"

int main()
{
	int port = 7777;
	printf("port: %d\n", port);
	printf("port to net: %d\n", htons(port));

	getchar();
    return 0;
}

    得到的结果如下:

port: 7777
port to net: 24862


· 大小端问题解决方法

    (1) 如果客户端和服务器是相同的字节序,只是长整数格式不同,则可以采用字符串传输数据。

    (2) 如果客户端和服务器是不同的字节序,可以显示的定义所支持数据类型的二进制格式,并以这样的格式在这两个之间传递。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值