测试字节序

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/YZC1078/article/details/76907285

·关于字节序
1.小端字节序(Little-Endian):低位存放在低地址,高位存放在高地址。

2.大端字节序(Big-Endian):高位存放在低地址,低位存放在高地址。

如图:
十六进制存储大小端存储关系

#include<stdio.h>
#include <arpa/inet.h>
int main(void)
{
        //声明一个临时变量
        unsigned int tmp = 0x12345678;
        unsigned char *p = (unsigned char*)&tmp;
        //打印临时变量,为本机字节序
        printf("0x12345678htonl()前:%x,%x,%x,%x\n", p[0], p[1], p[2], p[3]);

        //将临时变量大小位互换
        unsigned int y = htonl(tmp);
        p = (unsigned char*)&y;
        //打印字节序变换后变量
        printf("0x12345678htonl()后:%x,%x,%x,%x\n", p[0], p[1], p[2], p[3]);

        return 0;
}

测试结果如下:

实验结果

猜你喜欢

转载自blog.csdn.net/YZC1078/article/details/76907285