我建议你一个可能的解决方案。
不太好,不太快,有点脏,但我希望它能有所帮助。
#include <bitset>
#include <iostream>
int main ()
{
uint8_t test[16] = { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p' };
std::bitset<128> bsTest { } ;
for ( unsigned ui = 0 ; ui < 16 ; ++ui )
{
bsTest <<= 8;
std::bitset<128> bsTmp { (unsigned long) test[ui] };
bsTest |= bsTmp;
}
std::cout << bsTest;
return 0;
}
这个想法是将位集初始化为零
std::bitset<128> bsTest { } ;
uint8_t
并在另一个位集的末尾一次添加一个
std::bitset<128> bsTmp { (unsigned long) test[ui] };
然后合并(位或)两个位集
bsTest |= bsTmp;
并将结果移位 8 位
bsTest <<= 8;
ps:对不起我的英语不好