我遇到的主要问题是用C ++读取二进制值(python有一些非常快速/简单的函数来执行此操作)
我只需要同样的东西。所以目前我有:
ValWord< uint32_t> data1=//[SOME READ FUNCTION]
当我使用cout << data1;
时,它会给我一个数字,例如2147581953
我希望这是二进制的,并且最终每个“位”都需要在它自己的bin中,包括所有'0',例如:
for (int i = 31; i >= 0; i--) {
cout << binary[i];
}
会给我这个32位长的二进制数。当我把它作为直接转发int时,我已经使用过:
int data[32];
bitset<32>(N) = data1;
for(int i=31; i >=0; i--) {
data[i]=(bitset<32>(N[i]).to_ulong());
}
for (int i = 31; i >= 0; i--) {
cout << data[i];
}
但这只是给我错误信息。有什么想法吗?
答案 0 :(得分:2)
也许这个:
#define CPlusPlus11 0
#if CPlusPlus11
int main()
{
std::uint32_t value(42);
std::bitset<32> bits(value);
std::cout << bits.to_string() << std::endl;
// Storing integral values in the string:
for(auto i: bits.to_string(char(0), char(1))) {
std::cout << (int)i;
}
std::cout << std::endl;
return 0;
}
#else
int main()
{
std::uint32_t value(42);
std::bitset<32> bits(value);
std::cout << bits.to_string() << std::endl;
char data[32];
for(unsigned i = 0; i < 32; ++i) {
data[i] = bits[i];
}
for(unsigned i = 32; i; --i) {
std::cout << int(data[i-1]);
}
std::cout << std::endl;
return 0;
}
#endif
注意:您的表达式bitset<32>(N) = data1
和bitset<32>(N[i])
是代码味道。
答案 1 :(得分:1)
通常,将数字转换为给定基数的字符串是非常普遍的:
#include <cassert>
#include <string>
static char const Digits[] = "0123456789abcdefghijklmnopqrstuvwxyz";
static size_t const DigitsSize = sizeof(Digits) - 1;
static size_t const BufferSize = 32;
std::string convert(unsigned number, unsigned base) {
assert(base >= 2 and base <= DigitsSize);
char buffer[BufferSize] = {};
char* p = buffer + BufferSize;
while (number != 0) {
*(--p) = Digits[number % base];
number /= base;
}
return std::string(p, (buffer + BufferSize) - p);
}
注意:BufferSize
计算的最小基数为2,基数1和基数0是非敏感的。
注意:如果数字可以是负数,最简单的是事先测试它,然后使用它的反面;一个特别的警告是,32位整数的最小值的反面不能用基数2中的32位整数表示。
答案 2 :(得分:0)
我使用了一些简单的函数,使用stl,这里是二元函数:
#include <iostream>
#include <algorithm>
using namespace std;
string binary( unsigned long n )
{
string result;
do result.push_back( '0' + (n & 1) );
while (n >>= 1);
reverse( result.begin(), result.end() );
return result;
}
int main()
{
cout << binary(1024) << endl;
cout << "Hello World" << endl;
return 0;
}
希望这对你有用!
如果您需要更高性能的东西,请告诉我,我可以尝试为您添加一些汇编程序代码。