首页 > 代码库 > 位运算操作

位运算操作

除了static_stream还有stream可以进行按位读写之外,TBOX还提供了更加原始、更加底层的位数据操作接口,例如直接对某个数据指针的位读取操作,可以使用utils库的tb_bits_get_xxx和tb_bits_set_xxx 系列接口, 这个更加的轻量:

// p指向某个数据地址    tb_byte_t* p = data;    // 按大端读取16位数据    tb_uint16_t u16_be = tb_bits_get_u16_be(p);    // 按小端读取24位数据    tb_uint32_t u24_le = tb_bits_get_u24_le(p);    // 按本地端读取32位数据    tb_uint32_t u32_ne = tb_bits_get_u32_ne(p);    // 按大端读取64位数据    tb_uint64_t u64_be = tb_bits_get_u64_be(p);    // 读取从第1位开始的后续5位无符号数据    tb_uint32_t u5 = tb_bits_get_ubits32(p, 1, 5);    // 按大端读取浮点值    tb_float_t float_be = tb_bits_get_float_be(p);    // 按浮点大端、字小端读取双精度浮点值    tb_double_t double_ble = tb_bits_get_double_ble(p);    // 按浮点本地端、字本地端读取双精度浮点值    tb_double_t double_nne = tb_bits_get_double_nne(p);    // 交换无符号16位数值    u16 = tb_bits_swap_u16(u16);    // 交换无符号32位数值    u32 = tb_bits_swap_u32(u32);    // 交换无符号64位数值    u64 = tb_bits_swap_u64(u64);    // 将本地端的u32数值转为大端u32数值    u32_be = tb_bits_ne_to_be_u32(u32_ne);    // 将小端的u64值转为大端u64数值    u64_be = tb_bits_ne_to_be_u32(u64_le);    // 按大端顺序获取u32的前导0的位数    count = tb_bits_cl0_u32_be(val);    // 按小端顺序获取u64的前导1的位数    count = tb_bits_cl1_u64_le(val);    // 按大端顺序获取u32的第一个位0的索引位置    index = tb_bits_fl0_u32_be(val);    // 按小端顺序获取u64的第一个位1的索引位置    index = tb_bits_fl1_u64_le(val);    // 获取u32的位0的总数    count = tb_bits_cb0_u32(val);    // 获取u63的位1的总数    count = tb_bits_cb1_u64(val);

 

位运算操作