位运算操作

2014/08/29 15:56
阅读数 377

除了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);

展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
打赏
0 评论
4 收藏
0
分享
返回顶部
顶部