假设我们有一个字符串s=“453ACD0F”
。 现在我想做这样的事情:
uint32_t res = 0;
for (size_t i = 0; i < 8; ++i) {
res |= ConvertCharToHexNumber(s[8 - i - 1]) << (i * 4);
}
但是,如果我有一个从二进制文件读取的UINT32_TVAR
变量,我应该怎么做呢?
将4字节UINT32_T
转换为char[8]
的最简单方法:
uint32_t var = 100;
char res[8]{};
res[0] = (var >> 28) & 0XF;
res[1] = (var >> 24) & 0XF;
res[2] = (var >> 20) & 0XF;
res[3] = (var >> 16) & 0XF;
res[4] = (var >> 12) & 0XF;
res[5] = (var >> 8) & 0XF;
res[6] = (var >> 4) & 0XF;
res[7] = (var >> 0) & 0XF;
您可以将其简化为一个循环:
int shiftby = 32;
for (int i = 0; i < 8; i++) {
res[i] = (var >> (shiftby -= 4)) & 0xF;
}
我相信iomanip和流操作可能会帮到你。
#include <sstream>
#include <iomanip>
std::string s="453acd0f";
std::stringstream ss(s);
uint32_t res;
ss >> std::setbase(16) >> res; // hex. string to int. res==1161481487
ss.str(string());
ss.clear();
s.clear();
ss << std::setbase(16) <<res; // dec. int to hex. string.
s = ss.str(); // s==453acd0f
如果从二进制文件读取的uint32实际上是一个uint32,那么它除了被解释为一个无符号的32位整数之外,没有任何格式。 在这种情况下,读取数字,然后将其转换为十六进制表示形式。
所以举个例子:
std::ifstream ifs("file.dat", ios_base::binary);
char buffer[64];
uint32_t n;
ifs.read(buffer, sizeof(uint32_t));
memcpy(&n, buffer, sizeof(uint32_t));
std::cout << std::hex << n << endl;
剥猫皮的方法不止一种。 你可以直接读一下:
uint32_t n = 0xABC123;
// Get string representation of n
std::stringstream ss;
ss << std::hex << n;
// Pull out string, copy ptr to char array if you like
std::string s = ss.str();
// s.c_str() for example, for the C style string
std::cout << s << std::endl;
如果它将uint32_t读取为4字节,然后显示或保存Char*string的十六进制表示,我希望这能回答这个问题。