SX_union联合体在项目中的应用_7

在看项目源码的时候看到了实现某个功能用到了union联合体,仔细分析发现代码非常优雅

代码:

#include <stdio.h>
#include <stdint.h>
#include <arpa/inet.h>

extern uint16_t htons(uint16_t hostshort) __attribute__((const));

int main() {
    union {
        uint16_t s;
        uint8_t buf[sizeof(uint16_t)];
    } u_s;

    // 初始化联合体
    u_s.s = htons((uint16_t)1000);

    // 打印结果
    printf("u_s.s: %d\n", u_s.s);
    printf("size of uint16_t: %d\n", (int)sizeof(uint16_t));
    printf("size of int16_t: %d\n", (int)sizeof(int16_t));
    printf("u_s.buf: ");
    for (int i = sizeof(uint16_t) - 1; i >= 0; i--) {
        printf("buf[%d]: %d ", i, u_s.buf[i]);
    }
    printf("\n");
}

数字16的16进制表示为0x0010,数字4096的16进制表示为0x1000。 由于Intel机器是小尾端,存储数字16时实际顺序为1000,存储4096时实际顺序为0010。因此在发送网络包时为了报文中数据为0010,需要经过htons进行字节转换。如果用IBM等大尾端机器,则没有这种字节顺序转换,但为了程序的可移植性,也最好用这个函数。

上述的代码就是转换过程:

由于uint8_t是一字节,所以0x0010的前两位00会放在一个下标内,另一个会放在另一个下标内

saisi@ubuntu:~/Desktop/Myproject/socketcmm$ make run
./hton
u_s.s :59395
size uint16_t :2
size int16_t :2
us_s.buf: buf[1]:232 buf[0]:3

saisi@ubuntu:~/Desktop/Myproject/socketcmm$

232 * 16 * 16 + 3 = 59395
3 * 16 * 16 + 232 = 1000

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值