试想,假如让你从一个字节中c中起始位置为s,提取长度为l的bit,用最简单的方法提取,可能你会想到宏定义或者函数。
就不饶了,思来想去,最后采用创建一个二维数组的查表方法。表如下:
const unsigned char Get_Middle_Byte[8][9] = {
0x00, 0x80, 0xc0, 0xe0, 0xf0, 0xf8, 0xfc, 0xfe, 0xff,
0x00, 0x40, 0x60, 0x70, 0x78, 0x7c, 0x7e, 0x7f, 0x00,
0x00, 0x20, 0x30, 0x38, 0x3c, 0x3e, 0x3f, 0x00, 0x00,
0x00, 0x10, 0x18, 0x1c, 0x1e, 0x1f, 0x00, 0x00, 0x00,
0x00, 0x08, 0x0c, 0x0e, 0x0f, 0x00, 0x00, 0x00, 0x00,
0x00, 0x04, 0x06, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x02, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
本文介绍了一种使用查表法从指定字节中提取特定长度比特串的方法。通过创建一个预定义的二维数组,可以高效地实现从任意字节的特定位置开始提取指定长度的比特串,此方法适用于嵌入式系统等资源受限的环境。
147

被折叠的 条评论
为什么被折叠?



