首页 > 代码库 > 位运算操作
位运算操作
除了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);
位运算操作
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。